Django关于事务transaction.atomic()的使用方式
作者:天下·第二
这篇文章主要介绍了Django关于事务transaction.atomic()的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
Django事务transaction.atomic()使用
导入需要使用的包
from django.shortcuts import render from django.http import HttpResponse from django.views import View from django.db import transaction # 导入事务
类视图 (整个函数使用事务,@transaction.atomic装饰器)
class MyView(View): @transaction.atomic # transaction.atomic装饰器可以保证该函数中所有的数据库操作都在一个事务中。 def post(self, request): # 数据库操作1。。。 # 数据库操作2。。。 return HttpResponse('ok')
类视图 (函数体事务,保存点的使用)
class MyView2(View): @transaction.atomic def post(self, request): # 设置事务保存点 s1 = transaction.savepoint() # 可以设置多个保存点 # 数据库操作。。。 # 事务回滚 (如果发生异常,就回滚事务) transaction.savepoint_rollback(s1) # 可以回滚到指定的保存点 # 提交事务 (如果没有异常,就提交事务) transaction.savepoint_commit(s1) # 返回应答 return HttpResponse('ok')
函数体中使用
def func(request): with transaction.atomic(): sid = transaction.savepoint() try: serializer.is_valid(raise_exception=True) comment = serializer.save() handle_obj_files(comment, request) visitor_order.epilogue.add(comment) visitor_order.status = 'complete' visitor_order.save() except Exception as e: transaction.savepoint_rollback(sid) return api_bad_request(str(e)) else: transaction.savepoint_commit(sid) data = VisitorOrderRetrieveSerializer(visitor_order).data return api_success(data=data)
此方法和方法二类似
为什么需要with transaction.atomic()
django的事务回滚操作
1.为什么需要事务回滚操作?
2.SQL事务是什么?
3. 数据会安全
4. django为什么需要with transaction.atomic()?
with transaction.atomic(): issue_field = After.objects.get(id=issue_field_id) issue_field.is_abandoned = True issue_field.save() # if set is_abandoned to True, set all field value with this field is_abandoned to True all_issue_field_value = AfterSales.objects.update().filter(field=issue_id) for issue= in all_issue: issue.is_abandoned = True issue.save()
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。