django框架事务处理小结【ORM事务及原始sql,定制sql事务处理】

  

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

  

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

  

<强> 1。基于django orM的事务处理

  

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

  

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

        django。数据库导入连接,交易   …   def batch_execsql (sqlarray):   光标=connection.cursor() #得到处理的游标对象   ret=" "   试一试:   对于sql sqlarray:   cursor.execute (sql)   transaction.commit_unless_managed() #这是重点,没有这条语句,就不会提交。   除了例外,e: #简单的异常处理,可以忽略   ret=str (e)   cursor.close ()   返回ret #有异常则返回异常,否则返回为空字符串      之前      

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

  

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

  

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

  

2。对http请求的事务拦截,这是推荐的方式,使用了事务中间件来完成,这是比较好的方法,但必须在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之后的所有中间件都会受到事务的控制,所以当你把会话中间件放到事务之后,同样会受到影响。但,,不会受到影响,缓存机制有自己的处理方式,用了内部的连接来处理

  

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

  

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

  

<代码> @transaction。自动提交>         django。db进口事务   @transaction.autocommit   def viewfunc(请求):   …   @transaction.autocommit(使用=" my_other_database”)   def viewfunc2(请求):   …      之前      

b) <代码> @transaction.commit_on_success>         django。db进口事务   @transaction.commit_on_success   def viewfunc(请求):   …   @transaction.commit_on_success(使用=" my_other_database”)   def viewfunc2(请求):   …      之前      

c) <代码> commit_manually() ,完全自己处理,但如果你没有调用<代码> commit() 或者<代码> rollback()>         django。db进口事务   @transaction.commit_manually   def viewfunc(请求):   …   然而#你可以提交/回滚,每当你想要的   transaction.commit ()   …   #但是你要记得做自己!   试一试:   …   除了:   transaction.rollback ()   其他:   transaction.commit ()   @transaction.commit_manually(使用=" my_other_database”)   def viewfunc2(请求):   …      之前      

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

django框架事务处理小结【ORM事务及原始sql,定制sql事务处理】