【MySQL笔记】撤销删除—DCL中COMMIT与ROLLBACK的使用

目录

DCL中COMMIT和ROLLBACK

对比COMMIT和ROLLBACK

DDL和DML的说明

操作代码案例


DCL中COMMIT和ROLLBACK

DCL:数据控制语言,用来定义访问权限和安全级别

COMMIT:提交数据。一旦执行了 COMMIT,则数据就被永久的保存在了数据库中,意味着数据不可以回滚(回滚就是撤销的意思)

ROLLBACK:回滚数据。一旦执行 ROLLBACK,则可以实现数据的回滚,回滚到最近的一次 COMMIT 之后

对比COMMIT和ROLLBACK

相同点:都可以实现对表中所有数据的删除,同时保留表结构

不同点:TRUNCATE TABLE:一旦执行此操作,表数据全部清除。同时,数据是不可以回滚的

               DELETE FROM:一旦执行此操作,表数据可以全部清除(不带 WHERE),同时,数                据可以实现回滚

DDL和DML的说明

DML (Data Manipulation Language) 数据操纵语言

适用范围:对数据库中的数据进行一些简单操作,如 insert,delete,update,select 等

DDL (Data Definition Language) 数据定义语言

适用范围:对数据库中的某些对象 (例如,database,table) 进行管理,如 Create,Alter 和 Drop

1. DDL 的操作一旦执行,就不可回滚,指令 SET autocommit = FALSE 对 DDL 操作失效。(因为在执行完 DDL操作之后,一定会执行一次 COMMIT。因此 COMMIT 操作不受 SET autocommit = FALSE 的影响)

2. DML 的操作默认情况,一旦执行,也是不可以回滚的。但是,如果在执行 DML 之前,执行了 SET autocommit = FALSE,则执行的 DML 操作就可以实现回滚

操作代码案例

1
COMMIT;
2
SELECT *
FROM 表名;
3
SET autocommit = FALSE;
4
TRUNCATE TABLE 表名;
5
SELECT *
FROM 表名;
6
ROLLBACK;
7
SELECT *
FROM 表名;

DML 操作默认情况下,执行完以后都会自动提交数据在。如果希望执行完以后不自动提交数据,则需要使用  SET autocommit = FALSE

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java小白。。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值