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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值