溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決php數(shù)據(jù)庫事務(wù)遇到的問題

發(fā)布時(shí)間:2020-09-29 15:56:03 來源:億速云 閱讀:173 作者:小新 欄目:編程語言

這篇文章主要介紹如何解決php數(shù)據(jù)庫事務(wù)遇到的問題,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

在使用php的PDO擴(kuò)展的時(shí)候發(fā)現(xiàn)的一個(gè)問題,在事務(wù)開啟之后,如果php與mysql之間的連接斷開了,會(huì)導(dǎo)致php直接記錄一個(gè)warning的異常,而不是直接拋出一個(gè)Exception

流程如下:

/**
 * 一個(gè)用戶財(cái)產(chǎn)變更的場(chǎng)景下
 */

try {
    // 1. 開啟事務(wù)

    /**
     * 2. 變更用戶財(cái)產(chǎn),增加財(cái)產(chǎn)變更的流水記錄
     */

    // 3. 提交事務(wù)
} catch (\Exception $e) {
    // 4. 回滾事務(wù)

    // 5. 記錯(cuò)誤日志

    // 6. 拋出異常
}

// 7. 發(fā)布用戶財(cái)產(chǎn)變更的廣播

以上的操作可以簡(jiǎn)單的分成五類,在以前我的認(rèn)知當(dāng)中,操作事務(wù)的大致流程就是上面的樣子,沒有異常拋出則事務(wù)就是提交成功了的
但是直到有一天數(shù)據(jù)庫異常,有一個(gè)事務(wù)已經(jīng)開啟了,處在上面的1-2的過程當(dāng)中,數(shù)據(jù)庫直接掛掉,那么在步驟3提交事務(wù)的時(shí)候會(huì)直接出現(xiàn)一個(gè)warning級(jí)別的錯(cuò)誤,"SQLSTATE[HY000]: General error: 2006 MySQL server has gone away" ,沒有捕獲到異常
所以在步驟7的后續(xù)步驟中,其他業(yè)務(wù)方拿到了那條沒有提交的流水id并進(jìn)行了統(tǒng)計(jì),但是實(shí)際上用戶的財(cái)產(chǎn)并沒有增加。從而導(dǎo)致了問題

百思不得其解的時(shí)候去看了下文檔,發(fā)現(xiàn)了一個(gè)歷史遺留很久的bug:https://bugs.php.net/bug.php?...

后來我們通過臨時(shí)在事務(wù)的位置配置了set_error_handler解決了問題

以上是如何解決php數(shù)據(jù)庫事務(wù)遇到的問題的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI