Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with
or
.
Download ZIP
Browse files

Fixed #21235 -- Disabled savepoints for old versions of SQLite.

Thanks Ramiro for the report.
  • Loading branch information...
commit 91547772e04e456f45c7ef86e1f76d087821c89d 1 parent 8d75d1e
@aaugustin aaugustin authored
Showing with 7 additions and 3 deletions.
  1. +7 −3 django/db/backends/sqlite3/base.py
View
10 django/db/backends/sqlite3/base.py
@@ -393,12 +393,16 @@ def close(self):
BaseDatabaseWrapper.close(self)
def _savepoint_allowed(self):
+ # Two conditions are required here:
+ # - A sufficiently recent version of SQLite to support savepoints,
+ # - Being in a transaction, which can only happen inside 'atomic'.
+
# When 'isolation_level' is not None, sqlite3 commits before each
# savepoint; it's a bug. When it is None, savepoints don't make sense
- # because autocommit is enabled. The only exception is inside atomic
- # blocks. To work around that bug, on SQLite, atomic starts a
+ # because autocommit is enabled. The only exception is inside 'atomic'
+ # blocks. To work around that bug, on SQLite, 'atomic' starts a
# transaction explicitly rather than simply disable autocommit.
- return self.in_atomic_block
+ return self.features.uses_savepoints and self.in_atomic_block
def _set_autocommit(self, autocommit):
if autocommit:

0 comments on commit 9154777

Please sign in to comment.
Something went wrong with that request. Please try again.