Per-transaction isolation level in Django ORM(Django ORM 中的每个事务隔离级别)
问题描述
是否可以为自定义事务设置隔离级别(但不能使用原始 sql)?
Is it possible to set isolation level for custom transaction (but not with raw sql)?
例如,类似于:
with transaction.commit_on_success(isolation='SERIALIZABLE'):
bla
推荐答案
据我所知,没有办法在 Django 中临时更改现有数据库连接的事务隔离级别.
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.
例如在您的 settings.py 中:
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.postgresql',
'USER': 'postgres_user',
'PASSWORD': 's3krit',
'OPTIONS': {
'isolation_level': psycopg2.extensions.ISOLATION_LEVEL_SERIALIZABLE,
},
},
}
要使用可序列化事务级别,您可以:
To use the serializable transaction level, you could:
使用
using()QuerySet 方法例如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 中的每个事务隔离级别的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:Django ORM 中的每个事务隔离级别
基础教程推荐
- pyserial - 可以从线程 a 写入串行端口,是否阻塞从线程 b 读取? 2022-01-01
- 将 x 轴刻度更改为自定义字符串 2022-01-01
- 在 Celery 工作人员中捕获 Heroku SIGTERM 以优雅地关 2022-01-01
- Discord.py 缺少必需的参数 2022-01-01
- 由Python将MP3转换为MIDI(类型错误:无法加载插件:mtg-Melodia:Melodia) 2022-01-01
- 与常规 dict 相比,Python manager.dict() 非常慢 2022-01-01
- 尝试制作WhatsApp机器人 2022-01-01
- 使用生成器和迭代器时 Python 多循环失败 2022-01-01
- numpy float:比算术运算中内置的慢 10 倍? 2022-01-01
- 用 Python 编写 Fortran 无格式文件 2022-01-01
