django数据库事务

Posted hongpeng0209

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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="[email protected]")
            models.Group.objects.create(title="python")

    except Exception as e:
        return HttpResponse("出现错误....")
    return HttpResponse("ok")

  

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

  


以上是关于django数据库事务的主要内容,如果未能解决你的问题,请参考以下文章

BottomNavigationView 滞后于片段事务

如何在 Django Summernote 中显示编程片段的代码块?

Django 中事务的使用

python-django中使用事务以及小坑

Django 事务和并发

如何绕过将数据模型传递给片段参数以避免事务太大异常?