Rumah > Soal Jawab > teks badan
mysql如果一个事务一直没有commit并且也没有rollback会怎样?
有什么办法查询到这些没有被commit也没有被rollback的事务。?
PHPz2017-04-17 13:48:53
如果MySQL存在没有提交的事务,那么这时候 AUTOCOMMIT 自动提交的参数应该是为 0 的。
不过如果你通过其他的语言的MySQL驱动来操作的话,这些驱动一般都带有自动恢复 AUTOCOMMIT 的功能,在请求处理完成后会自动 ROLLBACK 没有处理的事务。
黄舟2017-04-17 13:48:53
数据库连接断开或者请求结束的时候一般会自动rollback
这是大家都会给出的答案,但实际上到底是服务器还是启动环境(FPM)还是代码的连接库操作的rollback呢???不太清楚,但我猜测应该是连接数据库工具类自动rolback的或者就是启动环境(FPM)直接在服务端准备返回数据给客户端的时候自动rollback
网上也有官方文档举例说 PHP-mysql是PDO(数据库驱动类库)自动调用的rollback。但也没说在具体什么时候断开。。。