首頁  >  文章  >  後端開發  >  nginx - 關於phpmysql的事務

nginx - 關於phpmysql的事務

WBOY
WBOY原創
2016-08-04 09:20:591177瀏覽

問題: 我發現事務沒有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沒有處理的事務。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn