首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >django-transaction 事务回滚

django-transaction 事务回滚

作者头像
Autooooooo
发布2020-11-09 11:24:59
1.2K0
发布2020-11-09 11:24:59
举报
文章被收录于专栏:CoxhuangCoxhuang

事务回滚

#0 GitHub

https://github.com/Coxhuang/django-transaction.git

#1 环境

Python3.6
Django==2.0.6

#2 需求

  • 用户的数据包括基本资料表A,特殊资料表B;在新增用户时,需要对表A和表B进行操作,如果A添加数据成功,但是B添加数据失败,此时,我们希望A的数据也被删除
  • 在支付的时候,如果支付中发生异常,那么异常之前的操作,我们也希望回到原始状态

#3 事务回滚

事务回滚就是在操作数据库时,如果发生异常,能让数据回到原来的状态

#4 使用

#4.1 新建一个django项目

没有使用事务回滚

def new_stu(request):
    models.Student.objects.create(name="cox_raise")
    raise Http404("异常")
    return HttpResponse("success")
在这里插入图片描述
在这里插入图片描述

使用事务回滚,但没有发生异常

from django.db import transaction
def new_stu(request):

    with transaction.atomic(): # 事务回滚
        models.Student.objects.create(name="cox2")
    return HttpResponse("success")
在这里插入图片描述
在这里插入图片描述

使用事务回滚,发生异常

from django.db import transaction


def new_stu(request):

    with transaction.atomic(): # 事务回滚
        models.Student.objects.create(name="cox_404")
        raise Http404("异常")
    return HttpResponse("success")
在这里插入图片描述
在这里插入图片描述

并没有生成数据

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-01-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 事务回滚
  • #0 GitHub
  • #1 环境
  • #2 需求
  • #3 事务回滚
  • #4 使用
    • #4.1 新建一个django项目
    相关产品与服务
    数据库
    云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档