Django关于事务transaction.atomic()的使用方式

 更新时间:2023年08月24日 09:43:17   作者:天下·第二  
这篇文章主要介绍了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()

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Python函数的迭代器与生成器的示例代码

    Python函数的迭代器与生成器的示例代码

    这篇文章主要介绍了Python函数的迭代器与生成器的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • Python读取文件比open快十倍的库fileinput

    Python读取文件比open快十倍的库fileinput

    fileinput是Python的内置模块,但不少人对它都是陌生的。今天把fileinput的所有的用法、功能进行详细的讲解,并列举一些非常实用的案例,对于理解和使用它可以说完全没有问题
    2021-10-10
  • 总结Pyinstaller的坑及终极解决方法(小结)

    总结Pyinstaller的坑及终极解决方法(小结)

    这篇文章主要介绍了总结Pyinstaller的坑及终极解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • 详解【python】str与json类型转换

    详解【python】str与json类型转换

    这篇文章主要介绍了【python】str与json类型转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Python读取实时数据流示例

    Python读取实时数据流示例

    今天小编就为大家分享一篇Python读取实时数据流示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • flask SQLAlchemy连接数据库及操作的实现

    flask SQLAlchemy连接数据库及操作的实现

    本文主要介绍了flask SQLAlchemy连接数据库及操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Flask之闪现flash原理及使用

    Flask之闪现flash原理及使用

    Flask中的闪现是一种在请求之间传递消息的机制,本文就来介绍一下Flask之闪现flash原理及使用,具有一定的参考价值,感兴趣的可以了解一下
    2023-12-12
  • Python学习笔记之Zip和Enumerate用法实例分析

    Python学习笔记之Zip和Enumerate用法实例分析

    这篇文章主要介绍了Python学习笔记之Zip和Enumerate用法,结合实例形式分析了Zip和Enumerate的功能、用法及相关操作注意事项,需要的朋友可以参考下
    2019-08-08
  • python错误处理详解

    python错误处理详解

    这篇文章主要介绍了python错误处理详解,本文讲解了try语句、错误堆栈、记录错误、抛出错误等内容,需要的朋友可以参考下
    2014-09-09
  • python操作ie登陆土豆网的方法

    python操作ie登陆土豆网的方法

    这篇文章主要介绍了python操作ie登陆土豆网的方法,涉及Python操作页面元素的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-05-05

最新评论