中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python django事務實例源碼解析

發布時間:2021-09-17 15:11:37 來源:億速云 閱讀:176 作者:chen 欄目:云計算

這篇文章主要講解了“python django事務實例源碼解析”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“python django事務實例源碼解析”吧!

python Django事務

# atomic() 方法   
# from django.db import transaction
###################
# atomic()
###################
def atomic(using=None, savepoint=True):    #  裝飾器和上下文管理器必須.()調用方法,因為真正的處理是該方法返回的實例,不是該方法本身
    if callable(using):
        return Atomic(DEFAULT_DB_ALIAS, savepoint)(using)
    # Decorator: @atomic(...) or context manager: with atomic(...): ...
    else:
        return Atomic(using, savepoint)
##########################################
#  Atomic類  省略了非核心內容
############################################
class Atomic(ContextDecorator):
  def __init__(self, using, savepoint):
    self.using = using
    self.savepoint = savepoint
  def __enter__(self):
    connection = get_connection(self.using)
    sid = connection.savepoint()            # 進入with創建一個保存點
    # .............do
  def __exit__(self, exc_type, exc_value, traceback):
    if connection.in_atomic_block:
    # do.............
    if sid is not None:
        try:
            connection.savepoint_commit(sid)        #  提交事務
        except DatabaseError:
            try:
                connection.savepoint_rollback(sid)    #  捕獲數據庫異常回滾
                connection.savepoint_commit(sid)
            except Error:
                connection.needs_rollback = True
            raise
    ## 還有一段代碼是exec_type收到其他程序異常時候 全局回滾,此處省略
    # do.................
###############################
# ContextDecorator
#################################
class ContextDecorator(object):
    def __call__(self, func):
        def inner(*args, **kwargs):
            with self:              #  把函數放進self的with上下文管理器,效果with相同,只是控制細粒度不同
                return func(*args, **kwargs)
        return inner

python MySQLdb

class Tran():
    def __init__(self, conn=None, close=True):
        if conn is None:                    # 創建數據庫鏈接
            print 'init'
            self.conn = conn_tbkt()
            self.cur = self.conn.cursor()
            self.sql = []

    def __enter__(self):                            # 上下文管理器返回 sql語句列表  with Tran('tbkt_pxb') as sqls:
        print 'enter'
        return self.sql     # sql.append('select 1')

    def __exit__(self, exc_type, exc_val, exc_tb):
        print 'exit'
        try:

            print self.sql                              # 執行sql
            for s in self.sql:
                self.cur.execute(s)
            self.conn.commit()
        except:                                             # 可以捕獲所有異常(django事務如果中間出現程序異常終止無法回滾)
            try:                    # 回滾本身也是sql執行,也有可能失敗
                import traceback
                traceback.print_exc()
                print 'rollback'
                self.conn.rollback()
            except:
                print u'回滾失敗'
        finally:
            self.cur.close()
            self.conn.close()

更細粒度的回滾:

# 在事務塊中@atomic() 或者 with atomic():
sid = transaction.savepoint('tbkt_pxb')
try:
  # do ..........
except:
  transaction.savepoint_rollback(sid, 'tbkt_pxb')

注意:如果有多個數據庫有路由,則需要指定和路由返回一致的useing: math3下的model需要事務,即使ziyuan_new和default是同一個庫,也必須使用useing=ziyuan_new

        ziyuan_app = ['math3', 'ziyuan']
        if model._meta.app_label in ziyuan_app:
            return "ziyuan_new"

        return 'default'

調用時候必須.()方法調用

atomic塊中必須注意try的使用,如果手動捕獲了程序錯誤會導致atomic包裝器捕獲不到異常,也就不會回滾。要么try內代碼不影響事務操作,要么就捕獲異常后raise出,讓atomic可以正常回滾(就是因為沒有注意到這個問題,導致嘗試了好幾天都沒成功,切記)

感謝各位的閱讀,以上就是“python django事務實例源碼解析”的內容了,經過本文的學習后,相信大家對python django事務實例源碼解析這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平阴县| 日喀则市| 邻水| 栖霞市| 平昌县| 宜兴市| 陈巴尔虎旗| 文登市| 稷山县| 呈贡县| 汤阴县| 湘西| 东安县| 花莲市| 鄂州市| 阜康市| 大埔县| 喜德县| 静乐县| 监利县| 白河县| 万荣县| 牙克石市| 于田县| 南召县| 沙河市| 吉林省| 阜宁县| 寿光市| 天等县| 远安县| 黔西县| 伽师县| 姚安县| 奉新县| 娄底市| 玛多县| 水城县| 镇江市| 青铜峡市| 涪陵区|