Django框架orM与自定义SQL语句混合事务控制操作
2019-06-27 11:16
1131 查看
本文实例讲述了Django框架orM与自定义SQL语句混合事务控制操作。分享给大家供大家参考,具体如下:
用单纯的ORM 或者单纯的自定义SQL语句,都比较好控制事务。在前面的一篇文章中已经讲过Django事务小结 ,但里面没有提到在同一个方法里面既有ORM 又有 自定义SQL 语句的情况。
如果是单纯的ORM ,可以这样做,假设已经定义好model, User,Category。
from django.db import transaction ... @commit_on_success def save_test(request): user=User(name="aaa",age=30) user.save() cat=Category(id=2,name="cat001") cat.save() .......
只有在程序成功执行,没错时,才会commit. 比如如果cat 保存出错,那么user 就会回滚。
如果是单纯的自定义SQL语句,可以通过如下方式实现
from django.db import connection, transaction ... def batch_execsql(sqlarray): print sqlarray cursor = connection.cursor() ret="" try: for sql in sqlarray: cursor.execute(sql) transaction.commit_unless_managed() except Exception,e: ret=str(e) cursor.close() return ret sqlarray=[] sqlarray.append("insert into table .......") sqlarray.append("update table set.......") ret=batch_execsql(sqlarray)
用这种方式,实现自定义SQL语句的事务,只要任何一条语句出错,就会回滚.
那么,如果ORM 与 自定义SQL 语句混合如何做呢,我在项目中结合了上面两种方式。比如按如下的方式
@commit_on_success def save_company_callinfo(request): response=HttpResponse() try: #==orm 保存部分====== .... model1.save() .... model2.save() ... #==自定义SQL 部分==== sqlarray=[] sqlarray.append("insert into table .......") sqlarray.append("update table set.......") ret=batch_execsql(sqlarray) if len(ret)>0: transaction.rollback() response.write('{"status":"no","error":"%s"}' % ('add call information error',)) else: response.write('{"status":"no","error":"%s"}' % ('',)) except Exception,e: response.write('{"status":"no","error":"%s"}' % (str(e),)) return response
这上面的过程可以自己修改成自己需要的,我用的是AJAX方式,因为我自己需要,但总体上ORM 与自定义SQL混合事务,就可以这么控制了。
希望本文所述对大家基于Django框架的Python程序设计有所帮助。
您可能感兴趣的文章:
相关文章推荐
- 获取django框架orm query执行的sql语句实现方法分析
- python3开发进阶-Django框架中的ORM的常用操作的补充(F查询和Q查询,事务)
- iBatis 事务控制 与 两表操作将SQL语句写入单表
- mysqli的多条sql语句操作以及简单的事务处理~~~~~
- LINQ体验(10)--LINQ to SQL语句之开放式并发控制和事务
- LINQ to SQL语句之开放式并发控制和事务
- 事务控制语句,begin,rollback,savepoint,隐式提交的SQL语句
- LINQ体验(10)——LINQ to SQL语句之开放式并发控制和事务
- django框架自定义模板标签(template tag)操作示例
- python3开发进阶-Django框架中的ORM的常用(增,删,改,查)操作
- oracle 中--怎么查看当前表空间在作什么操作?--查锁,死锁,当前执行时间长的Sql语句,没提交的事务,对象为哪些进程所用
- 执行一个SQL语句或者存储过程(无事务控制),返回一个内存表
- SQL之更新操作及事务控制
- LINQ to SQL语句(13)之开放式并发控制和事务
- Django框架(十一:orm操作之表的一对多)
- Django框架文件上传与自定义图片上传路径、上传文件名操作分析
- LINQ to SQL语句(13)之开放式并发控制和事务
- Django框架(十:orm操作)
- django执行自定义sql语句
- django框架自定义用户表操作示例