数据库之删除表数据drop、truncate和delete的⽤法
数据库中删除表数据的关键字,最常⽤的可能就是delete了,另外其实还有drop和truncate两个关键字。
⽼⼤:drop
命令格式:drop table  tb  ---tb表⽰数据表的名字,下同。
说明:删除内容和定义,释放空间。简单来说就是把整个表去掉.以后要新增数据是不可能的,除⾮新增⼀个表。
⽼⼆:truncate
命令格式:drop table  tb
说明:删除内容、释放空间但不删除定义,也就是数据表的结构还在。与drop不同的是,它只是清空表数据⽽已,它⽐较温柔。
⾄于释放空间,看下⾯两幅图就会明⽩:
上图Id标识列中,因之前delete过⾏数据,所以会出现标识列不连续(体现了delete删除是不释放空间的)。
上图是经过truncate table Teacher 之后⼜新增了三条数据,发现Id标识列插⼊数据的时候,标识列连续了(体现了truncate删除是释放空间)。注意:truncate 不能删除⾏数据,要删就要把表清空。
⽼三:delete
命令格式:delete table tb  或  delete table tb  where 条件
说明:删除内容不删除定义,不释放空间。其中,delete table tb 虽然也是删除整个表的数据,但是过程是痛苦的(系统⼀⾏⼀⾏地删,效率较truncate低)。
【关于truncate的总结】
1、truncate table 在功能上与不带 WHERE ⼦句的 delete语句相同,⼆者均删除表中的全部⾏,但 truncate ⽐ delete速度快,且使⽤的系统和事务⽇志资源少。
2、delete 语句每次删除⼀⾏,并在事务⽇志中为所删除的每⾏记录⼀项,所以可以对delete操作进⾏roll back。
3、truncate 在各种表上⽆论是⼤的还是⼩的都⾮常快。如果有ROLLBACK命令Delete将被撤销,⽽ truncate 则不会被撤销。
4、truncate 是⼀个DDL语⾔,向其他所有的DDL语⾔⼀样,它将被隐式提交,不能对 truncate 使⽤ROLLBACK命令。
truncate删除数据
5、truncate 将重新设置⾼⽔平线和所有的索引。在对整个表和索引进⾏完全浏览时,经过 truncate 操作后的表⽐Delete操作后的表要快得多。
6、truncate 不能触发任何Delete触发器。
7、当表被清空后表和表的索引讲重新设置成初始⼤⼩,⽽delete则不能。
8、不能清空⽗表。