django框架事务处理小结【ORM 事务及raw sql,customize sql 事务处理】


Posted in Python onJune 27, 2019

本文实例讲述了django框架事务处理。分享给大家供大家参考,具体如下:

django 中要求事务处理的情况有两种:

1.基于django orM 的 transaction 处理

2.是基于自定义SQL 语句的transaction的处理,通常是比较复杂的SQL ,用ORM 处理不方便的时候用的。或者是大批量SQL语句执行,比较在意效率的情况下用。

首先说一下第二种情况,因为这种情况相对简单一点,没ORM 那么多东西,用我写的一个方法来解释

from django.db import connection, transaction
.....
def batch_execsql(sqlarray):
  cursor = connection.cursor() # 得到处理的游标对象
  ret=""
  try:
    for sql in sqlarray:
      cursor.execute(sql)
    transaction.commit_unless_managed() # 这是重点,没有这条语句,就不会commit 。
  except Exception,e: #简单的异常处理,可以忽略
    ret=str(e)
  cursor.close()
  return ret #有异常则返回异常,否则返回为空字符串

由上面可以看出 transaction.commit_unless_managed()的重要性,这是自定义SQL 语句情况下处理事务的方法. 上面的例子中的 sqlarray 表示一个list,里面有很多自己写的SQL 语句,而这些语句要求在一个事务中完成。

再来看看第一种情况,用ORM 的时候,事务的处理. 这在django 的官方文档中有说明,下面简单翻译介绍下

1. django 默认的事务, 是自动处理的,当你在调用 orM 的model.save(),model.delete()的时候,所有改动会被立即提交的,相当于数据库设置了auto commit,没有隐藏的rollback.

2.对http请求的事务拦截,这是推荐的方式,使用了transaction中间件来完成,这是比较好的方法,但必须在settings.py中配置.

MIDDLEWARE_CLASSES = (
  'django.middleware.cache.UpdateCacheMiddleware',
  'django.contrib.sessions.middleware.SessionMiddleware',
  'django.middleware.common.CommonMiddleware',
  'django.middleware.transaction.TransactionMiddleware',
  'django.middleware.cache.FetchFromCacheMiddleware',
)

但需要注意的是,这样配置之后,与你中间件的配置顺序是有很大关系的。在 TransactionMiddleware 之后的所有中间件都会受到事务的控制。所以当你把session 中间件放到 Transaction之后,同样会受到影响。但  CacheMiddleware, UpdateCacheMiddleware, and FetchFromCacheMiddleware  不会受到影响,cache机制有自己的处理方式,用了内部的connection来处理

另外 TransactionMiddleware 只对 default 的数据库配置有效,如果要对另外的数据连接用这种方式,必须自己实现中间件。

3.自己来控制事务,这种情况下,你自己灵活控制事务.在settings.py 中不用配置 TransactionMiddleware 中间件了, 基本采用装饰模式来实现。

a) @transaction.autocommit ,django默认的事务处理, 采用此装饰模式会忽略掉全局的transaction 设置

from django.db import transaction
@transaction.autocommit
def viewfunc(request):
  ....
@transaction.autocommit(using="my_other_database")
def viewfunc2(request):
  ....

b) @transaction.commit_on_success 在一个方法中,所有工作完成后,提交事务。

from django.db import transaction
@transaction.commit_on_success
def viewfunc(request):
  ....
@transaction.commit_on_success(using="my_other_database")
def viewfunc2(request):
  ....

c) commit_manually() ,完全自己处理,但如果你没有调用commit()或者rollback(),将会抛出TransactionManagementError 异常.

from django.db import transaction
@transaction.commit_manually
def viewfunc(request):
  ...
  # You can commit/rollback however and whenever you want
  transaction.commit()
  ...
  # But you've got to remember to do it yourself!
  try:
    ...
  except:
    transaction.rollback()
  else:
    transaction.commit()
@transaction.commit_manually(using="my_other_database")
def viewfunc2(request):
  ....

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

Python 相关文章推荐
在Python中操作字符串之startswith()方法的使用
May 20 Python
python安装mysql-python简明笔记(ubuntu环境)
Jun 25 Python
基于python脚本实现软件的注册功能(机器码+注册码机制)
Oct 09 Python
基于Python的接口测试框架实例
Nov 04 Python
Python数据结构与算法之字典树实现方法示例
Dec 13 Python
Django数据库连接丢失问题的解决方法
Dec 29 Python
Python3.7 dataclass使用指南小结
Feb 22 Python
python中的协程深入理解
Jun 10 Python
如何为Python终端提供持久性历史记录
Sep 03 Python
PyCharm无法识别PyQt5的2种解决方法,ModuleNotFoundError: No module named 'pyqt5'
Feb 17 Python
解决Jupyter notebook中.py与.ipynb文件的import问题
Apr 21 Python
浅谈tf.train.Saver()与tf.train.import_meta_graph的要点
May 26 Python
python pytest进阶之conftest.py详解
Jun 27 #Python
详解Python 多线程 Timer定时器/延迟执行、Event事件
Jun 27 #Python
python pytest进阶之fixture详解
Jun 27 #Python
解决pycharm 远程调试 上传 helpers 卡住的问题
Jun 27 #Python
python中pytest收集用例规则与运行指定用例详解
Jun 27 #Python
python取余运算符知识点详解
Jun 27 #Python
如何运行.ipynb文件的图文讲解
Jun 27 #Python
You might like
PHP中include()与require()的区别说明
2010/03/10 PHP
php数据入库前清理 注意php intval与mysql的int取值范围不同
2010/12/12 PHP
fleaphp常用方法分页之Pager使用方法
2011/04/23 PHP
PHP删除数组中特定元素的两种方法
2019/02/28 PHP
JQuery从头学起第三讲
2010/07/06 Javascript
js显示时间 js显示最后修改时间
2013/01/02 Javascript
JavaScript instanceof 的使用方法示例介绍
2013/10/23 Javascript
js实现遮罩层划出效果是生成div而不是显示
2014/07/29 Javascript
javascript三元运算符用法实例
2015/04/16 Javascript
详解AngularJS中的表达式使用
2015/06/16 Javascript
jQuery实现Tab菜单滚动切换的方法
2015/09/21 Javascript
AngularJS控制器继承自另一控制器
2016/05/09 Javascript
禁用backspace网页回退功能的实现代码
2016/11/15 Javascript
Javascript 两种刷新方法以及区别和适用范围
2017/01/17 Javascript
vue的Virtual Dom实现snabbdom解密
2017/05/03 Javascript
vue组件初学_弹射小球(实例讲解)
2017/09/06 Javascript
代码整洁之道(重构)
2018/10/25 Javascript
vue Tab切换以及缓存页面处理的几种方式
2019/11/05 Javascript
vue中实现点击按钮滚动到页面对应位置的方法(使用c3平滑属性实现)
2019/12/29 Javascript
JS实现纸牌发牌动画
2021/01/19 Javascript
javascript实现倒计时关闭广告
2021/02/09 Javascript
如何搜索查找并解决Django相关的问题
2014/06/30 Python
PyTorch线性回归和逻辑回归实战示例
2018/05/22 Python
浅析Python 读取图像文件的性能对比
2019/03/07 Python
基于Python打造账号共享浏览器功能
2019/05/30 Python
python使用paramiko模块通过ssh2协议对交换机进行配置的方法
2019/07/25 Python
Python queue队列原理与应用案例分析
2019/09/27 Python
浅析HTML5:'data-'属性的作用
2018/01/23 HTML / CSS
Myprotein台湾官方网站:全球领先的运动营养品牌
2018/12/10 全球购物
寻找迷宫的一条出路,o通路;X:障碍
2016/07/10 面试题
什么是重载?CTS、CLS和CLR分别做何解释
2012/05/06 面试题
城市精细化管理实施方案
2014/03/04 职场文书
民主生活会意见
2015/06/05 职场文书
2016教师党员学习心得体会
2016/01/21 职场文书
简单实现一个手持弹幕功能+文字抖动特效
2021/03/31 HTML / CSS
SQL bool盲注和时间盲注详解
2022/07/23 SQL Server