Truncate和Delete有以下几点区别
1、Truncate在各种表上无论是大的还是小的都非常快。如果有ROLLBACK命令Delete将被撤销,而Truncate则不会被撤销。
2、Truncate是一个DDL语言,向其他所有的DDL语言一样,他将被隐式提交,不能对Truncate使用ROLLBACK命令。
3、Truncate将重新设置高水平线和所有的索引。在对整个表和索引进行完全浏览时,经过Truncate操作后的表比Delete操作后的表要快得多。
4、Truncate不能触发任何Delete触发器。
5、不能授予任何人清空他人的表的权限。
6、当表被清空后表和表的索引将重新设置成初始大小,而Delete则不能。
7、不能清空父表。
TRUNCATE TABLE (schema)table_name DROP(REUSE) STORAGE
在默认是 DROP STORAGE 当使用DROP STORAGE时将缩短表和表索引,将表收缩到最小范围,并重新设置NEXT参数。REUSE STORAGE不会缩短表或者调整NEXT参数
在特殊情况下使用 REUSE STORAGE
一个实际应用的典型例子:
你用sqlldr加载一个1000万记录的数据表,但是加载了多一半的时候你发现有问题,
这个时候你想清空表重新加载。
那么最好 reuse storage ,这样再次加载就不需要再次寻找空闲空间了
分享到:
相关推荐
TRUNCATE与 DELETE区别,比较两个的不同的特点
sql中 truncate 和 delete 有什么区别
sql之truncate、delete与drop区别
delete,truncate和drop的区别
truncate,delete以及drop区别汇总,需要可以自己下载看看,个人觉得蛮好的!
SQL语句中----删除表数据drop、truncate和delete的用法,对你爱不完
truncate,delete,drop的异同点
sql之truncate_、delete与drop区别.pdf sql之truncate_、delete与drop区别.pdf
truncate 和 delete 清空表数据的区别:truncate 是整体删除(速度较快),delete 是逐条删除(速度较慢);truncate 不激活
作为初学者,有时容易混淆truncate,delete,drop之间的根本区别,所有今日小记一下。。。
本文以一个简单实例为大家介绍了SQL中truncate和delete的区别,帮助大家理解,具体内容如下 ---创建表Table1 IF OBJECT_ID('Table1','U') IS NOT NULL DROP TABLE Table1 GO CREATE TABLE Table1 (ID INT NOT NULL,...
主要介绍了秒懂drop、truncate和delete的区别,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
详细阐述了Oracle中三种删除的方式truncate,drop和delete三者的区别和联系.
注意:这里说的delete是指不带where子句的delete语句 相同点 truncate和不带where子句的delete, 以及drop都会删除表内的数据 不同点: 1. truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被...
truncate和 delete只删除数据不删除表的结构(定义) drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger),索引(index); 依赖于该表的 存储过程/函数将保留,但是变为invalid状态. 2.delete语句是dml...
drop、delete、truncate都表示删除,但是三者有一些差别: Delete用来删除表的全部或者一部分数据行,执行delete之后,用户需要提交(commmit)或者回滚(rollback)来执行删除或者撤销删除。会触发这个表上所有的...
您可能感兴趣的文章:数据库中删除语句Drop、Delete、Truncate的相同点和不同点的比较(实例说明)drop,truncate与delete的区别详解MySQL中DROP,TRUNCATE 和DELETE的区别实现mysql从零开始浅析drop user与delete from ...