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语句同时插入成功或失败

  

posted @ 2018-08-13 16:14  hongpeng0209  阅读(307)  评论(0编辑  收藏  举报