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

作者:轻舞肥羊 时间:2022-02-27 23:20:03 

本文实例讲述了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程序设计有所帮助。

来源:http://www.yihaomen.com/article/python/267.htm

标签:django,事务处理
0
投稿

猜你喜欢

  • python实现飞船大战

    2022-09-19 02:17:26
  • pip安装python库时报Failed building wheel for xxx错误的解决方法

    2021-12-12 04:55:53
  • JDBC连接MySQL数据库关键的四个步骤

    2009-12-17 12:06:00
  • 在ASP.NET 2.0中操作数据之十一:基于数据的自定义格式化

    2023-07-14 19:53:21
  • 利用机器学习预测房价

    2023-08-10 21:25:50
  • HTML编写小经验

    2011-06-14 09:43:14
  • 去掉运行JavaScript时IE产生的警告栏

    2008-09-11 18:07:00
  • 什么是gzip,人肉gzip?

    2008-11-20 13:01:00
  • Python命令行参数解析工具 docopt 安装和应用过程详解

    2022-01-15 05:31:05
  • SQLServer WITH 的用法

    2009-07-09 18:54:00
  • 让ThinkPHP的模板引擎达到最佳效率的方法详解

    2023-11-14 17:06:40
  • 提高JavaScript执行效率的23个实用技巧

    2023-08-15 18:38:12
  • Python3 pip3 list 出现 DEPRECATION 警告的解决方法

    2021-02-24 10:21:59
  • 怎样用cmd命令行运行Python文件

    2023-07-15 00:25:11
  • python 利用百度API进行淘宝评论关键词提取

    2021-11-14 19:32:36
  • MySQL教程:Group By用法

    2009-02-26 15:27:00
  • 微信小程序wx.request拦截 器使用详解

    2023-07-22 09:11:55
  • 轻松接触SQL Server 2000实例的命名规则

    2009-01-23 13:44:00
  • 处理SQL Server 2000的命名实例和多实例

    2009-01-19 13:28:00
  • asp脚本延时 自定义的delay函数

    2008-04-07 12:59:00
  • asp之家 网络编程 m.aspxhome.com