1
0
mirror of https://github.com/django/django.git synced 2025-01-27 02:29:55 +00:00

[4.2.x] Fixed #30601 -- Doc'd the need to manually revert all app state on transaction rollbacks.

Backport of aa80b357fbef46e5b6faa08d63bcfd4fe21f3776 from main
This commit is contained in:
lufafajoshua 2023-10-27 15:05:31 +03:00 committed by Natalia
parent ffba63180c
commit 696fbc32d6

View File

@ -187,7 +187,7 @@ Django provides a single API to control database transactions.
If you catch exceptions raised by raw SQL queries, Django's behavior
is unspecified and database-dependent.
.. admonition:: You may need to manually revert model state when rolling back a transaction.
.. admonition:: You may need to manually revert app state when rolling back a transaction.
The values of a model's fields won't be reverted when a transaction
rollback happens. This could lead to an inconsistent model state unless
@ -210,6 +210,14 @@ Django provides a single API to control database transactions.
if obj.active:
...
This also applies to any other mechanism that may hold app state, such
as caching or global variables. For example, if the code proactively
updates data in the cache after saving an object, it's recommended to
use :ref:`transcation.on_commit <performing-actions-after-commit>`
instead, to defer cache alterations until the transaction is actually
committed.
In order to guarantee atomicity, ``atomic`` disables some APIs. Attempting
to commit, roll back, or change the autocommit state of the database
connection within an ``atomic`` block will raise an exception.
@ -290,6 +298,8 @@ by Django or by third-party libraries. Thus, this is best used in situations
where you want to run your own transaction-controlling middleware or do
something really strange.
.. _performing-actions-after-commit:
Performing actions after commit
===============================