问题: 我发现事务没有commit也没有rollback的时候,会在此次http请求结束后自动rollback
代码例子:
立即学习“PHP免费学习笔记(深入)”;
$this->db->begin(); // 这时候user表这条记录就已经被锁住了。。。 $user = \Users::findFirst($id); $user->name = '写锁啊!'; sleep(15); $user->save(); return ;
但是等到这次请求结束的时候数据库这条记录又能编辑了。。。
我想问 到底是nginx 还是 fpm 还是phalcon 自动调用的PDO->rollback(); ??????
问题: 我发现事务没有commit也没有rollback的时候,会在此次http请求结束后自动rollback
代码例子:
立即学习“PHP免费学习笔记(深入)”;
$this->db->begin(); // 这时候user表这条记录就已经被锁住了。。。 $user = \Users::findFirst($id); $user->name = '写锁啊!'; sleep(15); $user->save(); return ;
但是等到这次请求结束的时候数据库这条记录又能编辑了。。。
我想问 到底是nginx 还是 fpm 还是phalcon 自动调用的PDO->rollback(); ??????
MySQL的AUTOCOMMIT自动提交的参数默认是打开的,在事务里遇到commit命令才会提交
如果是通过其他语言的MySQL驱动来操作的话,在请求结束(完成或超时),MySQL的驱动会自动ROLLBACK没有处理的事务。
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号