亲宝软件园·资讯

展开

MySQL delete Truncate drop

共黄昏 人气:0

参考文章:链接

一、删除的内容

delete

删除表中的数据,不删除表结构,但不释放空间

truncate

删除表中的数据,不删除表结构,释放空间;

drop drop

语句删除表结构及所有数据,并将表所占用的空间全部释放。

结论:TRUNCATE 和DELETE只删除数据, DROP则删除整个表(结构和数据)。

二、删除过程

三、表和索引所占空间

四、应用范围

五、删除程度

drop > truncate > delete

六、处理速度

结论:

原因:

DELETE 语句每次删除一行,并在事务日志中为所删除的每行记录一项。TRUNCATE TABLE 通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。

七、语句类型:

注意:在没有备份情况下,谨慎使用 drop 与 truncate。要删除部分数据行采用delete且注意结合where来约束影响范围。回滚段要足够大。要删除表用drop;若想保留表而将表中数据删除,如果于事务无关,用truncate即可实现。如果和事务有关,或总是想触发trigger,还是用delete。

八、语法区别

delete 删除表中数据(where 可写可不写,写的话进行选择性删除,不写的话则清空表中的数据)

DELETE FROM 表名称 WHERE 列名称 = 值

truncate 删除表中的数据,无法回滚

truncate table tbl_name 
或者 
truncate tbl_name

drop删除数据库

DROP DATABASE [ IF EXISTS ] <数据库名>

drop删除表

DROP table [ IF EXISTS ] <表名>

注意:drop和truncate不能够激活触发器,因为该操作不记录各行删除;

九、总结

delete

truncate

drop

加载全部内容

相关教程
猜你喜欢
用户评论