开发者

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

开发者 https://www.devze.com 2023-11-19 10:45 出处:网络 作者: 天下·第二
目录Django事务transaction.atomic()使用类视图 (整个函数使用事务,@transaction.atomic装饰器)类视图 (函数体事务,保存点的使用)函数体中使用为什么需要with transaction.atomic()django的事务回滚操作总结Django事
目录
  • Django事务transaction.atomic()使用
    • 类视图 (整个函数使用事务,@transaction.atomic装饰器)
    • 类视图 (函数体事务,保存点的使用)
    • 函数体中使用
  • 为什么需要with transaction.atomic()
    • django的事务回滚操作
  • 总结

    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()
            tpythonry:
                serializejsr.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.为什么需要事务回滚操作?

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

    2.SQL事务是什么?

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

    3. 数据会安全

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

    4. django为什么需要with transaction.atomic()?

    Django关于事务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_ilICgwid)
                    for issue= in all_issue:
                        issue.is_abandoned = True
                        issue.save()

    总结

    编程客栈上为个人经验,希望能给大家一个参考,也希望大家多多支持编程客栈(www.devze.com)。

    0

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    关注公众号