MySQL数据库DDL DML DQL 的区别 drop delete truncate的区别

SQL语言分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL.

简单的说DML语句就是增删改(INSERT,DELETE,UPDATE)

DDL就是对数据库对象操作的语句(CREATE,DROP,TRUNCATE)等

何为数据库对象:数据库商们将表,索引,视图,同义词等都称为数据库对象。

所以区分DDL和DML的方法其实在语句字面上就可以看到,DDL语句都是在动作+对象的格式,比如create是动作,说明要创建什么,table就是对象,所以create table就是DDL,其他的DDL同样,没注意过的可以去看一看。DML语句则是动作+具体的对象名,比如insert into + 表明等,相信大家从来也没有见过insert table,update table这样的写法吧?

1. truncate 和 delete 只删除数据不删除表的结构(定义)
drop 语句将删除表的结构被依赖的约束(constrain)、触发器(trigger)、索引(index);依赖于该表的存储过程/函数将保留,但是变为 invalid 状态。

2. delete 语句是数据库操作语言(dml),这个操作会放到 rollback segement 中,事务提交之后才生效;如果有相应的 trigger,执行的时候将被触发。
truncate、drop 是数据库定义语言(ddl),操作立即生效,原数据不放到 rollback segment 中,不能回滚,操作不触发 trigger。

你可能感兴趣的:(数据库,MySQL)