数据库中truncate、delete、drop三种删除的区别

delete:delete from 表名 where ****

delete可以删除行数据,也可以对整表数据删除,一般与where关联使用。delete删除内容,释放内容空间,但是表结构和表定义不删除。

truncate:truncate table 表名

truncate只清除表中的内容,释放内容所占空间,但是表结构和表定义不删除。其次truncate不能删除行数据,比delete删除的彻底。

drop:drop table 表名

drop删除数据和定义,释放空间,它会将表的结构也一起删除掉。

更多细节

1、delete每次删除一行时,都会将该行的删除操作作为事务记录在日志中。以便进行回滚操作。

2、执行速度:drop > truncate > delete:因为delete每执行一次,都要在事务日志中记录一次。所以最慢

3、delete语句是数据库操作语言(dml),这个操作会放到rollback segement(回滚分段)中,事务提交以后才会生效,若有相应的trigger(触发),执行的时候将被触发。

4、truncate、drop是数据库定义语言(ddl),操作立即生效,原数据不放到rollback segment中,不能回滚,操作不触发trigger

5、truncate语句执行以后,id标识还是按照顺序排列,保持连续;而delete语句执行后,id标识不连续。

注意事项

1、由于truncate、drop立即生效,不能回滚,所以谨慎使用。

2、采用delete删除数据时,和where连用最保险,且要有足够大的回滚段,防止删除错误数据好及时恢复。

3、对于外键约束引用的表,不能使用truncate table,而应该使用带where的delete语句,由于truncate table不记录在日志中,所以它不能激活触发器。

学习链接:https://blog.csdn.net/ws0513/article/details/49980547

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值