mirror of
				https://github.com/django/django.git
				synced 2025-10-26 07:06:08 +00:00 
			
		
		
		
	[1.7.x] Documentation fixes for the select_for_update change.
Refs #22343; thanks Tim Graham for the fixes.
Backport of 59b1d30 from master
			
			
This commit is contained in:
		| @@ -1378,7 +1378,7 @@ do not support ``nowait``, such as MySQL, will cause a | ||||
| :exc:`~django.db.DatabaseError` to be raised. This is in order to prevent code | ||||
| unexpectedly blocking. | ||||
|  | ||||
| Executing a queryset with ``select_for_update`` in autocommit mode is | ||||
| Evaluating a queryset with ``select_for_update`` in autocommit mode is | ||||
| an error because the rows are then not locked. If allowed, this would | ||||
| facilitate data corruption, and could easily be caused by calling, | ||||
| outside of any transaction, code that expects to be run in one. | ||||
|   | ||||
| @@ -17,19 +17,19 @@ executed in autocommit mode, outside of a transaction. Before Django | ||||
| lock records until the next write operation. Django 1.6 introduced | ||||
| database-level autocommit; since then, execution in such a context | ||||
| voids the effect of ``select_for_update()``. It is, therefore, assumed | ||||
| now to be an error, and raises an exception. | ||||
| now to be an error and raises an exception. | ||||
|  | ||||
| This change was made because such errors can be caused by including an | ||||
| app which expects global transactions (e.g. :setting:`ATOMIC_REQUESTS | ||||
| <DATABASE-ATOMIC_REQUESTS>` set to ``True``), or Django's old autocommit | ||||
| behavior, in a project which runs without them; and further, such | ||||
| errors may manifest as data-corruption bugs. | ||||
|  | ||||
| This change may cause test failures if you use ``select_for_update()`` | ||||
| in a test class which is a subclass of | ||||
| :class:`~django.test.TransactionTestCase` rather than | ||||
| :class:`~django.test.TestCase`. | ||||
|  | ||||
| This change was made because such errors can be caused by including an | ||||
| app which expects global transactions (e.g. :setting:`ATOMIC_REQUESTS | ||||
| <DATABASE-ATOMIC_REQUESTS>` set to True), or Django's old autocommit | ||||
| behavior, in a project which runs without them; and further, such | ||||
| errors may manifest as data-corruption bugs. | ||||
|  | ||||
| Other bugfixes and changes | ||||
| ========================== | ||||
|  | ||||
|   | ||||
| @@ -1096,21 +1096,20 @@ executed in autocommit mode, outside of a transaction. Before Django | ||||
| lock records until the next write operation. Django 1.6 introduced | ||||
| database-level autocommit; since then, execution in such a context | ||||
| voids the effect of ``select_for_update()``. It is, therefore, assumed | ||||
| now to be an error, and raises an exception. | ||||
| now to be an error and raises an exception. | ||||
|  | ||||
| This change was made because such errors can be caused by including an | ||||
| app which expects global transactions (e.g. :setting:`ATOMIC_REQUESTS | ||||
| <DATABASE-ATOMIC_REQUESTS>` set to ``True``), or Django's old autocommit | ||||
| behavior, in a project which runs without them; and further, such | ||||
| errors may manifest as data-corruption bugs. It was also made in | ||||
| Django 1.6.3. | ||||
|  | ||||
| This change may cause test failures if you use ``select_for_update()`` | ||||
| in a test class which is a subclass of | ||||
| :class:`~django.test.TransactionTestCase` rather than | ||||
| :class:`~django.test.TestCase`. | ||||
|  | ||||
| This change was made because such errors can be caused by including an | ||||
| app which expects global transactions (e.g. :setting:`ATOMIC_REQUESTS | ||||
| <DATABASE-ATOMIC_REQUESTS>` set to True), or Django's old autocommit | ||||
| behavior, in a project which runs without them; and further, such | ||||
| errors may manifest as data-corruption bugs. | ||||
|  | ||||
| This was also fixed in Django 1.6.3. | ||||
|  | ||||
| Miscellaneous | ||||
| ~~~~~~~~~~~~~ | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user