MySQL第八课 Truncate的用法

使用场景安全

                当你再也不须要该表时, 用 drop;当你仍要保留该表,但要删除全部记录时, 用 truncate;当你要删除部分记录时(always with a WHERE clause), 用 delete.ide


TRUNCATE、Drop、Delete区别函数

删除表中的数据的方法有delete,truncate, 其中TRUNCATE TABLE用于删除表中的全部行,而不记录单个行删除操做。TRUNCATE TABLE 与没有 WHERE 子句的 DELETE 语句相似;可是,TRUNCATE TABLE 速度更快,使用的系统资源和事务日志资源更少spa


 具体分析
 1.drop和delete只是删除表的数据(定义),drop语句将删除表的结构、被依赖的约束(constrain)、触发器 (trigger)、索引(index);依赖于该表的存储过程/函数将保留,可是变为invalid状态。
日志

2.delete语句是DML语言,这个操做会放在rollback segement中,事物提交后才生效;若是有相应的触发器(trigger),执行的时候将被触发。truncate、drop是DDL语言,操做后即 生效,原数据不会放到rollback中,不能回滚,操做不会触发trigger。
3.delete语句不影响表所占用的extent、高水线(high watermark)保持原位置不动。drop语句将表所占用的空间所有释放。truncate语句缺省状况下将空间释放到minextents的 extent,除非使用reuse storage。truncate会将高水线复位(回到最初)。
4.效率方面:drop > truncate > delete
5.安全性:当心使用drop与truncate,尤为是在 没有备份的时候,想删除部分数据可以使用delete须要带上where子句,回滚段要足够大,想删除表能够用drop,想保留表只是想删除表的全部数据、 若是跟事物无关可使用truncate,若是和事物有关、又或者想触发 trigger,仍是用delete,若是是整理表内部的碎片,能够用truncate跟上reuse stroage,再从新导入、插入数据。
6.delete是DML语句,不会自动提交。drop/truncate都是DDL语句,执行后会自动提交。
七、drop通常用于删除总体性数据 如表,模式,索引,视图,完整性限制等;delete用于删除局部性数据 如表中的某一元组
八、DROP把表结构都删了;DELETE只是把数据清掉
九、当你再也不须要该表时, 用 drop;当你仍要保留该表,但要删除全部记录时, 用 truncate;当你要删除部分记录时(always with a WHERE clause), 用 delete.orm

相关文章
相关标签/搜索