mysql如果一个事务一直没有commit并且也没有rollback会怎样?
巴扎黑
巴扎黑 2017-04-17 13:46:53
0
4
920

mysql如果一个事务一直没有commit并且也没有rollback会怎样?
有什么办法查询到这些没有被commit也没有被rollback的事务。?

巴扎黑
巴扎黑

全員に返信(4)
PHPzhong

如果MySQL存在没有提交的事务,那么这时候 AUTOCOMMIT 自动提交的参数应该是为 0 的。
不过如果你通过其他的语言的MySQL驱动来操作的话,这些驱动一般都带有自动恢复 AUTOCOMMIT 的功能,在请求处理完成后会自动 ROLLBACK 没有处理的事务。

いいねを押す +0
阿神

在连接超时时, 那个连接没有commit的事务会被rollback

いいねを押す +0
左手右手慢动作

1、断开链接会自动rollback
2、死锁或者这个锁超时的时候,也会rollback

いいねを押す +0
黄舟

数据库连接断开或者请求结束的时候一般会自动rollback

这是大家都会给出的答案,但实际上到底是服务器还是启动环境(FPM)还是代码的连接库操作的rollback呢???不太清楚,但我猜测应该是连接数据库工具类自动rolback的或者就是启动环境(FPM)直接在服务端准备返回数据给客户端的时候自动rollback

网上也有官方文档举例说 PHP-mysql是PDO(数据库驱动类库)自动调用的rollback。但也没说在具体什么时候断开。。。

いいねを押す +0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!