Mysql 事务失效的场景

DDL

所有的 DDL 语句都会导致事务隐式提交,换句话说,当你在执行 DDL 语句前,事务就已经提交了。这就意味着带有 DDL 语句的事务将来没有办法 rollback。
image.png
到第六步的时候,我们发现查询到的数据只剩三条了,说明第五步的回滚并没有生效。原因就在于执行 alter 之前,事务已经被隐式提交了。
所以小伙伴们在日常开发中,最好不要在事务中混有 DDL 语句,DDL 语句和 DML 语句分开写。
对于上面的案例,如果大家去掉第四步的 alter,那么回滚是可以回滚成功的,这个小伙伴们自己来测试,我就不演示了。
当然 DDL 操作可不仅仅是 alter,其他的如 CREATE、DROP 等操作也会导致事务隐式提交,这里松哥就不一一举例了,小伙伴们可以自行尝试。

DCL

DDL 和 DML 大家应该经常接触到,但是 DCL 可能有小伙伴不清楚,DCL 其实就是 Data Control Language,中文译作数据控制语言,我们日常授权或者回收数据库上的权限所使用的 GRANT、REVOKE 等,就算是 DCL 操作。
image.png
可以看到,跟第一小节的测试步骤一样,只不过第四步换成一个 GRANT 语句,那么最终的事务回滚也会失效,原因就在于事务已经提交了。
当然,除了 GRANT 和 REVOKE 之外,其他的创建、更新或者删除用户的操作也会导致事务隐式提交。主要有:

  • CREATE USER…
  • DROP USER…
  • ALTER USER…
  • SET PASSWORD…

开新事务

一个事务还没提交,结果你又开启了一个新的事务,那么此时前一个事务也会隐式提交。看个例子:
image.png

各种锁操作

给表上锁、解锁也会导致事务隐式提交
image.png
上锁的 SQL 如 lock tables table_name read|write,会导致事务隐式提交,解锁的 SQL 如 unlock tables 也会导致事务被隐式提交。
除了表锁,一些全局锁如 FTWRL 也会导致事务的隐式提交,如下:
image.png

从机的操作

我们在从机上执行的一些操作如 start slave、stop slave、reset slave 以及 change master to 等语句也会隐式提交事务。

其他表操作

其他的一下操作如刷新权限(flush privileges)、优化表(optimize table)、修复表(repair table)等操作,也会导致事务的隐式提交。
image.png
image.png
image.png

总结

那么多隐式提交,我怎么记得住呀?其实不用背,你只要记着事务里只写增删改查(INSERT/DELETE/UPDATE/SELECT),就不会错啦!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL事务可以失效的几个场景包括: 1. 隐式提交:如果在一个事务还未提交的情况下,开启了一个新的事务,那么前一个事务会隐式提交,导致事务失效。这是因为MySQL默认使用自动提交模式,每个SQL语句都被视为一个独立的事务,如果没有明确使用BEGIN或START TRANSACTION语句来开启事务,那么每个SQL语句都会被隐式提交。 2. 并发操作:在并发的情况下,多个事务同时进行读写操作时,可能出现幻读、不可重复读等问题,从而导致事务的隔离性受到干扰。例如,当一个事务在读取某个数据的同时,另一个事务对该数据进行了修改,那么前一个事务可能无法得到一致的数据,从而导致事务失效。 3. 锁操作:在使用锁进行并发控制时,如果锁的粒度不当或者锁的使用方式不正确,可能导致事务失效。例如,当一个事务在读取某个数据的同时,另一个事务对该数据进行了锁定,那么前一个事务可能无法继续执行,从而导致事务失效。 需要注意的是,MySQL事务失效并不是指整个事务都无效,而是指某些操作或某些隔离性可能受到干扰,导致事务无法达到预期的结果。为了确保事务的有效性,建议合理使用事务的隔离级别、锁机制,并注意事务的提交和回滚操作。 参考资料: MySQL 5.7 Reference Manual - 15.3.2 事务控制语句:https://dev.mysql.com/doc/refman/5.7/en/transaction-control-statements.html MySQL 5.7 Reference Manual - 13.2.1 InnoDB 事务隔离级别:https://dev.mysql.com/doc/refman/5.7/en/innodb-transaction-isolation-levels.html

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值