問題: 我發現事務沒有commit也沒有rollback的時候,會在此次http請求結束後自動rollback
程式碼範例:
<code>$this->db->begin(); // 这时候user表这条记录就已经被锁住了。。。 $user = \Users::findFirst($id); $user->name = '写锁啊!'; sleep(15); $user->save(); return ; </code>
但是等到這次請求結束的時候資料庫這筆記錄又能編輯了。 。 。
我想問 到底是nginx 還是 fpm 還是phalcon 自動呼叫的PDO->rollback(); ??????
問題: 我發現事務沒有commit也沒有rollback的時候,會在此次http請求結束後自動rollback
程式碼範例:
<code>$this->db->begin(); // 这时候user表这条记录就已经被锁住了。。。 $user = \Users::findFirst($id); $user->name = '写锁啊!'; sleep(15); $user->save(); return ; </code>
但是等到這次請求結束的時候資料庫這筆記錄又能編輯了。 。 。
我想問 到底是nginx 還是 fpm 還是phalcon 自動呼叫的PDO->rollback(); ??????
MySQL的AUTOCOMMIT自動提交的參數預設是打開的,在事務裡遇到commit命令才會提交
如果是透過其他語言的MySQL驅動來操作的話,在請求結束(完成或超時),MySQL的驅動會自動ROLLBACK沒有處理的事務。