飞道的博客

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

478人阅读  评论(0)

一. SQL 中的语法

drop table 表名称                                       
truncate table 表名称             
delete from 表名称 where 列名称 =

二. drop,truncate,delete 的区别

1.drop (删除表)

删除表中的内容和定义的表的数据结构。
简单来说就是把整个表删除,以后要新增数据是不可能的,除非新建立一个表,然后再插入数据。

2.truncate (清空表中的数据)

删除表中的内容、释放占有的空间但不删除定义(保留表的数据结构)。
与drop不同的是,只是清空表内的数据而已,原表有 8 行,清空口表中还有 0 行数据。

3.delete (删除表中的数据)

delete 语句用于删除表中的行。
delete 语句执行删除的过程是每次从表中删除一行,并且同时将该行的删除操作作为一个事务,记录在日志中保存,以便删除失败后进行回滚操作。


  • truncate 表名;
    ----- 删除表中的所有行,但表结构及其列、约束、索引等保持不变。

  • 如果要删除表定义及其数据,请使用 drop table 语句。

  • 执行速度,一般来说: drop> truncate > delete。


转载:https://blog.csdn.net/HU1656/article/details/105180893
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场