码迷,mamicode.com
首页 > 其他好文 > 详细

drop,delete与truncate的区别

时间:2020-09-12 21:46:31      阅读:58      评论:0      收藏:0      [点我收藏+]

标签:开始   约束   依赖   删除   初始   HERE   tab   不能   bsp   

drop直接删掉表,truncate删除表中数据,再插入时自增长id又从1开始,delete删除表中数据,可以加where字句。

1.delete 语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为事务记录在日志 中保存以便进行回滚操作。truncate table则一次性地从表中删除所有的数据并不把单独的删除操作记 录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器,执行速 度快。

2.表和索引所占空间。当表被truncate后,这个表和索引所占用的空间会恢复到初始大小,而delete操 作不会减少表或索引所占用的空间。drop语句将表所占用的空间全释放掉。

3.一般而言,drop>truncate>delete

4.应用范围。truncate只能对table,delete可以是table和view

5.truncate和delete只删除数据,而drop则删除整个表(结构和数据) 

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

 

 

drop,delete与truncate的区别

标签:开始   约束   依赖   删除   初始   HERE   tab   不能   bsp   

原文地址:https://www.cnblogs.com/sea-stream/p/13592643.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!