Django ORM中的每个交易隔离级别 [英] Per-transaction isolation level in Django ORM
问题描述
是否可以为自定义事务设置隔离级别(但不能使用原始sql设置隔离级别)?
例如,类似以下内容:
with transaction.commit_on_success(isolation ='SERIALIZABLE'):
bla
据我所知,对于现有的数据库连接,无法临时更改Django中的事务隔离级别。 / p>
但是,您可以设置另一个数据库连接,该数据库连接可以反映您的默认数据库连接,但可以设置事务隔离级别。
例如在您的settings.py中:
DATABASES = {
'default':{
'NAME': 'app_data',
'ENGINE':'django.db.backends.postgresql',
'USER':'postgres_user',
'PASSWORD':'s3krit',
},
'serializable':{
'NAME':'app_data',
'ENGINE':'django.db.backends.postgresl',
'USER':' postgres_user',
'PASSWORD':'s3krit',
'OPTIONS':{
'isolation_level':psycopg2.extensions.ISOLATION_LEVEL_SERIALIZABLE,
},
},
}
要使用可序列化的交易级别,您可以:
- 使用
using()
QuerySet方法
例如User.objects.using('serializable')。all
-
添加自定义管理器,它指定具有事务隔离级别的数据库连接
class SerializableUserManager(models.Manager):
def get_queryset(self):
返回super(SerializableUserManager,self).get_queryset() .using('serializable')
Is it possible to set isolation level for custom transaction (but not with raw sql)?
For example, something like:
with transaction.commit_on_success(isolation='SERIALIZABLE'):
bla
As far as I know, there's no way to temporarily change the transaction isolation level in Django for an existing database connection(s).
However, you could setup another database connection(s) that mirrors your default database connection(s) but sets the transaction isolation level.
e.g. in your settings.py:
DATABASES = {
'default': {
'NAME': 'app_data',
'ENGINE': 'django.db.backends.postgresql',
'USER': 'postgres_user',
'PASSWORD': 's3krit',
},
'serializable': {
'NAME': 'app_data',
'ENGINE': 'django.db.backends.postgresl',
'USER': 'postgres_user',
'PASSWORD': 's3krit',
'OPTIONS': {
'isolation_level': psycopg2.extensions.ISOLATION_LEVEL_SERIALIZABLE,
},
},
}
To use the serializable transaction level, you could:
- Use the
using()
QuerySet method e.g.User.objects.using('serializable').all
Add a custom manager that specifies the database connection with the transaction isolation level
class SerializableUserManager(models.Manager): def get_queryset(self): return super(SerializableUserManager, self).get_queryset().using('serializable')
这篇关于Django ORM中的每个交易隔离级别的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!