设为首页 加入收藏

TOP

truncatetable与delete区别
2015-07-24 10:43:30 来源: 作者: 【 】 浏览:1
Tags:truncatetable delete 区别

truncate table需要drop table权限,它是完全清空一张表。 从逻辑上看,truncate table同delete 一样,或是drop table +create table一样。使用truncate table删除全表数据,要比delete要快。使用truncate table清空数据,不能进行回滚,且不受表间外键约束限制。 truncate是DDL语句,而且delete是DML语句,两者区别如下: 1.truncate 是邮drop table+create table ,比使用delete一行行删除数据要快得多,特别是清空大数据的表。 2.truncate是一种隐匿提交,所以不能进行回滚。 3.若当前表有外键约束,truncate table 可以清空表中的所有数据,不受外键约束限制。 4.使用truncate table将自增ID置零,delete则不会。 5.在使用分区表时,截断表保存分区;也就是说,数据和索引文件删除并重新创建,在分区定义(.par)文件不受影响。 6.TRUNCATE TABLE语句不调用删除触发器。

参考:

http://dev.mysql.com/doc/refman/5.7/en/truncate-table. html http://dev. mysql.com/doc/refman/5.6/en/optimizing-innodb-ddl-operations.html
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇CentOS下配置phpMyAdmin 下一篇POJO类以及映射配置文件

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·C++ Lambda表达式保 (2025-12-26 05:49:45)
·C++ Lambda表达式的 (2025-12-26 05:49:42)
·深入浅出 C++ Lambda (2025-12-26 05:49:40)
·C语言指针从入门到基 (2025-12-26 05:21:36)
·【C语言指针初阶】C (2025-12-26 05:21:33)