zoukankan      html  css  js  c++  java
  • django数据库事务

    数据库原子操作

    举个例子:

    一个消费者在一个商户里刷信用卡消费,交易正常时,银行在消费者的账户里减去相应的款项,在商户的帐户加上相应的款项。但是如果银行从消费者的账户里扣完钱之后,还未在商户的帐户里加上相应的款项时,由于某些原因,系统或者数据库出现异常了,那么此时钱已经从消费者的账户里扣除了,但是商户的账户里却没有加上相应的款项,这种情况下,最好的解决办法就是使用数据库的原子性操作,也就是数据库的事务。保证要么同时成功,要么同时失败,然后才向数据库commit。

    Django默认向数据库的提交方式

    Django的默认行为是在自动提交模式下运行。除非事务处于活动状态,否则每个查询都会立即提交到数据库。

    Django自动使用事务或保存点来保证需要多个查询的ORM操作的完整性,尤其是delete()和update()查询。

    事务提交后执行任务

    有时您需要执行与当前数据库事务相关的操作,但前提是事务成功提交。示例可能包括celery任务,电子邮件通知或缓存失效

    Django提供了on_commit()注册回调函数的函数,这些函数应在成功提交事务后执行

    from django.db import transaction
    
    def do_something():
        pass  # send a mail, invalidate a cache, fire off a Celery task, etc.
    
    transaction.on_commit(do_something)
    

      

    django如何实现事务

    from django.db import transaction
    
    def create(request):
        try:
            with transaction.atomic():
                models.Userinfo.objects.create(username="stu01", email="stu01@qq.com")
                models.Group.objects.create(title="python")
    
        except Exception as e:
            return HttpResponse("出现错误....")
        return HttpResponse("ok")
    

      

    这样两条sql语句同时插入成功或失败

      

  • 相关阅读:
    Oracle 查询表空间容量脚本
    C#保留小数位的方法集合
    asp.net c# 去掉字符串中重复项并将结果遍历出来算法
    汇总sql server数据库所有表名、列数、行数
    Web表单设计之注册表单
    精简高效的CSS命名准则和方法
    MSSQL查看和解除表锁
    XML通用操作类
    Ajax学习笔记一(xmlHttpRequest对象)
    SQL Server无法生成FRunCM线程|FRunCM 线程|FRunCM
  • 原文地址:https://www.cnblogs.com/hongpeng0209/p/9468912.html
Copyright © 2011-2022 走看看