zoukankan      html  css  js  c++  java
  • Avoid catching exceptions inside atomic! You may need to manually revert model state when rolling back a transaction. 避免异常程序不抛错误 回滚 导致 自增id不连续。

    https://docs.djangoproject.com/en/3.0/topics/db/transactions/

    You may need to manually revert model state when rolling back a transaction.

    The values of a model’s fields won’t be reverted when a transaction rollback happens. This could lead to an inconsistent model state unless you manually restore the original field values.

    For example, given MyModel with an active field, this snippet ensures that the ifobj.active check at the end uses the correct value if updating active to True fails in the transaction:

    from django.db import DatabaseError, transaction
    
    obj = MyModel(active=False)
    obj.active = True
    try:
        with transaction.atomic():
            obj.save()
    except DatabaseError:
        obj.active = False
    
    if obj.active:
        ...




    id 不连续




    User.objects.get(x=y)注意这种写法 当且仅当需要x=y的情况下才不会抛异常 exception ;raise ParamError(CustomerError.X_NOT_EXIST)
    可以使得事务回滚;但是 不raise error 不会使得事务回滚。


    回滚 导致 自增id不连续。





  • 相关阅读:
    Spark算子--join
    Spark算子--filter
    Spark算子--reduceByKey
    Spark算子--mapPartitions和mapPartitionsWithIndex
    Spark算子--map和flatMap
    Flume环境搭建_五种案例
    枚举深入剖析
    Oracle_基本函数查询综合
    Oracle_复杂查询综合
    softmax 杂谈
  • 原文地址:https://www.cnblogs.com/rsapaper/p/12776499.html
Copyright © 2011-2022 走看看