ROLLBACK有什么作用?

正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

1回答
提问者 洛奇丶大 2019-07-10 09:07:02

是在COMMIT加一个ROLLBACK之后,这些被操作的数据被标记了。如果CMOOIT之后发现有问题,还可以回滚到没COMMIT之前。

但是COMMIT之前没加ROLLBACK的数据不可以回滚

是这个意思吗?

  • 同学,您好,同学的理解是有问题的噢,commit提交数据之后是不能回滚的,ROLLBACK指的是【回滚】,即是在事务的运行过程中,发生了某种故障,事务不能继续执行,系统将事务中对数据库的所有的已完成的操作全部撤销,回滚到事务开始之前的状态。 如果我的回答解决了您的疑惑,望采纳!!^_^ 祝学习愉快~~~~~
    2019-07-10 10:23:26
  • 提问者 洛奇丶大 回复 慕猿梦 #2
    没明白 START TRANSACTION # 开启了一个事务 delete..... delete..... update.... ROLLBACK # 加在这里的意思是上面有任意一条语句执行错误就回滚到没执行之前?不对啊,我这里并没有COMMIT数据,没必要回滚啊。 能说一下ROLLBACK具体的使用场景让我加深一下理解吗?
    2019-07-10 11:53:19
  • 提问者 洛奇丶大 回复 慕猿梦 #3
    还是说这么理解 START TRANSACTION # 开启了一个事务 ...........N条sql语句 此时这里必须加COMMIT或者ROLLBACK来结束事务。 如果想把数据同步到文件中就用COMMIT,把数据同步到文件中。 如果以上语句有问题,那么就用ROLLBACK结束事务,但是不同步数据到文件中。
    2019-07-10 11:56:34
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师