这篇文章主要介绍“Django事务回滚如何实现”,在日常操作中,相信很多人在Django事务回滚如何实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Django事务回滚如何实现”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
一般来说,事务是必须满足4个条件(ACID)::原子性(Atomicity,或称不可分割性)、一致性(Consistency)、隔离性(Isolation,又称独立性)、持久性(Durability)。
原子性:一个事务(transaction)中的所有操作,要么全部完成,要么全部不完成,不会结束在中间某个环节。事务在执行过程中发生错误,会被回滚(Rollback)到事务开始前的状态,就像这个事务从来没有执行过一样。
一致性:在事务开始之前和事务结束以后,数据库的完整性没有被破坏。这表示写入的资料必须完全符合所有的预设规则,这包含资料的精确度、串联性以及后续数据库可以自发性地完成预定的工作。
隔离性:数据库允许多个并发事务同时对其数据进行读写和修改的能力,隔离性可以防止多个事务并发执行时由于交叉执行而导致数据的不一致。事务隔离分为不同级别,包括读未提交(Read uncommitted)、读提交(read committed)、可重复读(repeatable read)和串行化(Serializable)。
持久性:事务处理结束后,对数据的修改就是永久的,即便系统故障也不会丢失。
Django中对于数据库的事务,默认每执行一句数据库操作,便会自动提交,我们需要在保存订单中自己控制数据库事务的执行流程
调用@transaction.atomic,进行整体回滚
from django.db import transaction @transaction.atomic def viewfunc(request): # 这些代码会在一个事务中执行 #...
from django.db import transaction def viewfunc(request): # 这部分代码不在事务中,会被Django自动提交 #... with transaction.atomic(): # 这部分代码会在事务中执行 #...
注:装饰器和with语句直接使用会导致异常没有办法处理,如果需要处理异常,则可以通过以下的方式进行
from django.db import transaction def viewfunc(request): # 这部分代码不在事务中,会被Django自动提交 #... try: with transaction.atomic(): # 这部分代码会在事务中执行 #... except 异常: # 处理异常的代码
需要注意的是要和装饰器进行配合
from django.db import transaction @transaction.atomic def viewfunc(request): # 这部分代码不在事务中,会被Django自动提交 #... try: # 在事务开始前创建保存点 save_id = transaction.savepoint() # 这部分代码会在事务中执行 #... # 提交从保存点到当前状态的所有数据库事务操作 transaction.savepoint_commit(save_id) except 异常: # 回滚到保存点 transaction.savepoint_rollback(save_id) # 处理异常的代码
到此,关于“Django事务回滚如何实现”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。