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 的官方文档中有说明,下面简单翻译介绍下