目录
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