MySQL事务中DDL语句的隐式提交

前言

事务是一组组合成逻辑工作单元的操作,虽然系统中可能会出错,但事务将控制和维护事务中每个操作的一致性和完整性。如果数据库支持事务,则可以将数据库操作组成一个事务,以防止因这些事件而使数据库出现不一致。如果事务中的某个点发生故障,则所有更新都可以回滚到事务开始之前的状态。如果没有发生故障,则通过以完成状态提交事务来完成更新。

正常状态下的事务回滚

创建一张表test用来测试,表中只有name这一个字段
test表结构
开启事务
开启事务
向表中添加’zy’
向表中添加'zy'
回滚事务并在此查看表
事务回滚
表中什么都没有,说明回滚成功。这是一次非常简单的回滚,接下来演示
一下隐式提交情况下的回滚。

DDL语句的隐式回滚

现在表test中依然没有数据,只有name一个字段,开始操作。
开启事务,同上。
向test表中添加’zy’
向test中添加'zy'
创建另一张表test1,只有一个字段id
创建表test1
回滚事务并查看‘zy’是否添加成功,表test1是否成功创建

回滚事务并查看
数据添加成功,并且表也创建成功,那么回滚就失败了。从代码的角度看,是没有什么问题的,但是为什么会失败呢?

WHY

其实是这样的,当我们执行了DDL语句之后,系统会自动的执行一次commit,连带着前面的添加数据一起完成了提交。所以当我们再次rollback的时候,其实执行的是一个空的事务。表面上看到的是回滚失败了,但是其实并不是,回滚其实是成功了的,但是因为回滚的是一个空的事务,所以直观上是看不到任何变化的。而且,不论DDL是否执行成功,都会完成一次提交。

总结:DDL语句会进行隐式提交,是不能再rollback的,所以大家在操作中一定要注意。

tips:为什么DDL语句会隐式提交?
因为DDL是数据定义语言,在我们的数据库中承担着创建,删除和修改的重要的职责。一旦发生问题,带来的后果很可能是不可估量的。于是在每执行完一次后就进行提交,可以保证流畅性,数据不会发生阻塞,同时也会提高数据库的整体性能。

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值