首頁 > 後端開發 > php教程 > nginx - 關於phpmysql的事務

nginx - 關於phpmysql的事務

WBOY
發布: 2016-08-04 09:20:59
原創
1188 人瀏覽過

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板