摘要:問題描述我自己以擴(kuò)展為基礎(chǔ),封裝了一個異步任務(wù)服務(wù)器框架,數(shù)據(jù)庫操作使用擴(kuò)展,但是在插入數(shù)據(jù)的時候,出現(xiàn)了異常情況,具體狀況如下表引擎的正常插入,沒有問題表引擎查詢都可以的,但是插入失敗,出現(xiàn)回滾現(xiàn)象,字段變化,表的變化,正常返回解決過程監(jiān)
問題描述
我自己以swoole擴(kuò)展為基礎(chǔ),封裝了一個異步任務(wù)服務(wù)器框架,數(shù)據(jù)庫操作使用pdo擴(kuò)展,但是在插入數(shù)據(jù)的時候,出現(xiàn)了異常情況,具體狀況如下:
MyISAM 表引擎的insert正常插入,沒有問題
Innodb表引擎查詢都可以的,但是插入失敗,出現(xiàn)回滾現(xiàn)象,auto_increment字段變化,表的rows變化,lastInsertId正常返回
解決過程監(jiān)控mysql日志,查看狀態(tài)
進(jìn)入mysql命令行,查看mysql的general-log狀態(tài)
show global variables like "%genera%";
如果沒有開啟,執(zhí)行如下命令
;general_log_file_path修改為自己象牙iode set global general_log_file="general_log_file_path"; set global general_log=on
然后監(jiān)控日志,發(fā)現(xiàn)insert語句發(fā)送到mysql端了
查看innodb engine狀態(tài)
懷疑是不是死鎖了,查看innodb 的狀態(tài)
show engine innodb status;
沒有發(fā)現(xiàn)異常
到這里,已經(jīng)有些抓狂了
然后google,各種嘗試,都不得要領(lǐng)
糾結(jié)了挺長時間,后來看到有人說innodb引擎把insert當(dāng)作一個事物處理,瞬間想到了一個問題,是不是pdo擴(kuò)展里面,沒有自動提交?
直接寫了個簡單的mysql pdo 連接數(shù)據(jù)庫,并且插入數(shù)據(jù)到innodb表里面,結(jié)果沒有任何問題,成功了,然后我就想到pdo里面有個參數(shù)PDO::ATTR_AUTOCOMMIT,是不是他在作怪?
使用getAttribute(PDO::ATTR_AUTOCOMMIT)) 獲取他的值,打印,發(fā)現(xiàn)是1,證明是自動提交事務(wù)的
然后在我封裝的框架里面,我打印了他的值,發(fā)現(xiàn)是0,問題找到
那么,在插入的時候,如何提交事務(wù)?
連接數(shù)據(jù)庫的時候,options里面設(shè)置 PDO::ATTR_AUTOCOMMIT 為 1
插入操作的時候,自己執(zhí)行commit,顯式的完成一次事務(wù),我采用了這個方法
遺留問題是,同樣的PHP版本,為啥多帶帶的連接 PDO::ATTR_AUTOCOMMIT為1 ,在啟動的swoole-httpserer里面是0,我沒有繼續(xù)深入。
總結(jié)解決問題一定要持之以恒,不要放棄,那么問題最終會獲得比較理想的處理結(jié)果
另外要注意方法,嘗試不同的思路,我就是一直沒有想到可能是事務(wù)自動提交導(dǎo)致的,以至于浪費(fèi)了很多時間
最后,希望goolge不要被封鎖的這么嚴(yán)重,媽的,百度 必應(yīng)搜索結(jié)果完全沒法和google比,程序員,離不開google
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/21102.html
摘要:操作數(shù)據(jù)庫的種形式使用擴(kuò)展類庫推薦使用擴(kuò)展類庫這是類庫的升級版,但已經(jīng)不推薦使用擴(kuò)展包含哪三個類與區(qū)別可以支持多種數(shù)據(jù)庫,而且操作方法一致只支持?jǐn)?shù)據(jù)庫如何使用連接數(shù)據(jù)庫什么是如何關(guān)閉連接通過來連接數(shù)據(jù)庫,其中必須傳入數(shù)據(jù)源名稱數(shù)據(jù)源名稱是 PHP操作數(shù)據(jù)庫的2種形式 使用 PDO 擴(kuò)展類庫(推薦) 使用 Mysqli 擴(kuò)展類庫(這是Mysql類庫的升級版,但已經(jīng)不推薦使用) PDO...
摘要:在不指定的情況下,默認(rèn)版本號為。具體示例如下在需要更新數(shù)據(jù)庫的模式時,需要更新版本號。此時我們指定一個高于之前版本的版本號,就會觸發(fā)事件。數(shù)據(jù)操作事務(wù)在中,我們也能夠使用事務(wù)來進(jìn)行數(shù)據(jù)庫的操作。 概述 本文通過對IndexedDB的使用方法和使用場景進(jìn)行相關(guān)介紹,對常見的問題進(jìn)行解答。 同時,因?yàn)镸DN中的相關(guān)文檔缺乏相關(guān)邏輯性,所以不容易理解。本文將通過項(xiàng)目中常見的數(shù)據(jù)存儲和操作需求...
閱讀 3319·2023-04-25 14:35
閱讀 3430·2021-11-15 18:00
閱讀 2594·2021-11-12 10:34
閱讀 2512·2021-11-11 16:54
閱讀 3491·2021-10-08 10:12
閱讀 2775·2021-09-06 15:02
閱讀 3334·2021-09-04 16:48
閱讀 2809·2019-08-29 14:02