事务可以说是一段sql 语句的批处理,但是这个批处理是一个atom(原子) ,不可分割,要么都提交执行,要么回滚(rollback)都不执行。关于事务的详细定义介绍,我们在之前的文章中已经给大家介绍过了,需要的朋友可以先参考了解。
【mysql数据表中事务是什么意思】
【怎么开启Mysql数据表中的事务】
那么这里的事务提交和事务回滚是什么意思?又怎么实现?
下面我们依然结合一些简单的例子给大家进行详细说明。
一、事务提交(commit)
成功的结束,将所有的DML(insert、update、delete)语句 *** 作历史记录和底层硬盘数据来一次同步。
比如,现在有money这张表,其中有两条数据,ID为1和ID为2 的金额分别是7000和8000。
然后我们通过“start transaction”语句开启事务。
再对表中数据进行一些更新 *** 作,如下图中所示,我们分别对表中ID为1和ID为2的人增加金额5000。
那么我们在之前的文章【怎么开启MysqL数据表中手动事务】中,有说到事务开启后,再更新数据的话,数据库中的真实数据是不会有变化的,只是将记录更新到事务日志中。如果想要数据同步更新到数据库中,我们就需要进行事务提交 *** 作。
这里就需要大家掌握事务提交的语法:
commit;
事务提交后,我们再通过Navicat检查下数据表中的数据是否发生了变化。
如图事务提执行交即确认后,才能对真实的表数据进行改变。
二、事务回滚(rollback)
失败的结束,将所有的DML语句 *** 作历史记录全部清空。
在进行上面的事务提交 *** 作后,money表中的数据已经变为12000和13000了。
这里我们再重新开启事务,并再进行一系列更新数据 *** 作。
事务回滚的基本语法:
rollback;
那么从图中我们可以发现,当我们进行事务回滚 *** 作后,在开启事务之后的一系列 *** 作都会被清空,也就是说进行事务回滚后,数据库中数据依然不会发生任何变化。
注意:如果事务中所有SQL语句执行正确则需要自己手动提交commit;否则有任何一条执行错误,需要自己提交一条rollback,这时会回滚所有 *** 作,而不是commit会给你自动判断和回滚。
本篇文章就是关于MysqL数据表手动事务提交和事务回滚的相关知识介绍,通俗易懂,希望对需要的朋友有所帮助!
想要了解更多MysqL知识,可以关注PHP中文网mysql视频教程,欢迎大家参考学习! 总结
以上是内存溢出为你收集整理的Mysql事务提交及事务回滚是什么意思全部内容,希望文章能够帮你解决Mysql事务提交及事务回滚是什么意思所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)