×

truncate和delete的区别 delete run

truncate和delete的区别(比较truncate和delete命令有什么不同)

admin admin 发表于2022-09-04 03:33:10 浏览141 评论0

抢沙发发表评论

本文目录

比较truncate和delete命令有什么不同


truncate相当于删除数据的时候不放进垃圾箱,直接清除掉,速度快!
delete删数据的时候还可以rollback,速度慢,消耗内存。

delete与truncate有什么区别


truncate与delete的区别

  • 在功能上,truncate是清空一个表的内容,它相当于delete from table_name。

  • delete是dml操作,truncate是ddl操作;因此,用delete删除整个表的数据时,会产生大量的roolback,占用很多的rollback segments, 而truncate不会。

  • 在内存中,用delete删除数据,表空间中其被删除数据的表占用的空间还在,便于以后的使用,另外它是“假相”的删除,相当于windows中用delete删除数据是把数据放到回收站中,还可以恢复,当然如果这个时候重新启动系统(OS或者RDBMS),它也就不能恢复了!
    而用truncate清除数据,内存中表空间中其被删除数据的表占用的空间会被立即释放,相当于windows中用shift+delete删除数据,不能够恢复!-delete

  • truncate 调整high water mark 而delete不;truncate之后,TABLE的HWM退回到 INITIAL和NEXT的位置(默认)delete 则不可以。

  • truncate 只能对TABLE,delete 可以是table,view,synonym。

希望对你有帮助


DELETE 与 TRUNCATE 有什么不同


TRUNCATE和DELETE有以下几点区别
1、TRUNCATE在各种表上无论是大的还是小的都非常快。如果有ROLLBACK命令DELETE将被撤销,而TRUNCATE则不会被撤销。
2、TRUNCATE是一个DDL语言,向其他所有的DDL语言一样,他将被隐式提交,不能对TRUNCATE使用ROLLBACK命令。
3、TRUNCATE将重新设置高水平线和所有的索引。在对整个表和索引进行完全浏览时,经过TRUNCATE操作后的表比DELETE操作后的表要快得多。
4、TRUNCATE不能触发任何DELETE触发器。
5、不能授予任何人清空他人的表的权限。
6、当表被清空后表和表的索引讲重新设置成初始大小,而delete则不能。
7、不能清空父表。
-run

oracle中truncate和delete命令有何区别


truncate
table
在功能上与不带
where
子句的
delete
语句相同:二者均删除表中的全部行。但
truncate
table

delete
速度快,且使用的系统和事务日志资源少。
delete
语句每次删除一行,并在事务日志中为所删除的每行记录一项。
truncate
table
通过释放存储表数据所用的数据页来删除数据,并且只在事务日志中记录页的释放。
truncate,delete,drop放在一起比较:
truncate
table:删除内容、释放空间但不删除定义。
delete
table:删除内容不删除定义,不释放空间。
drop
table:删除内容和定义,释放空间。
1、truncate在各种表上无论是大的还是小的都非常快。如果有rollback命令delete将被撤销,而truncate则不会被撤销。
2、truncate是一个ddl语言,向其他所有的ddl语言一样,他将被隐式提交,不能对truncate使用rollback命令。
3、truncate将重新设置高水平线和所有的索引。在对整个表和索引进行完全浏览时,经过truncate操作后的表比delete操作后的表要快得多。
4、truncate不能触发任何delete触发器。
5、不能授予任何人清空他人的表的权限。
6、当表被清空后表和表的索引讲重新设置成初始大小,而delete则不能。
7、不能清空父表。
-delete

求答案: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
ST
DELETE语句执行删除的过程是每次从表中删除一行,并且同时将该行的的删除操作作为事务记录在日志中保存以便进行进行回滚操作。
TRUNCATE
TABLE
则一次性地从表中删除所有的数据页并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
-run

数据库命令delete和truncate的区别是什么


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 ST DELETE语句执行删除的过程是每次从表中删除一行,并且同时将该行的的删除操作作为事务记录在日志中保存以便进行进行回滚操作。 TRUNCATE TABLE 则一次性地从表中删除所有的数据页并不把单独的删除操作记录记入日志保存,删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器。执行速度快。
-delete

drop,truncate和delete的区别


drop table emp 把整个emp表从数据库中删除了,你查询select * from emp时会报错,提示表名为emp的表不存在
delete from emp where empno=257 delete删除的是表里某条数据,删除的是内容
truncate table emp 同样删除的也是内容,跟delete的区别是,这个是不可回滚的,也就是说删除了就是永久删除了,不能再撤回,而delete还可回滚,跟你平时在电脑上删除某个文件后悔了然后在回收站恢复一样,但truncate的效率高
truncate table emp执行之后,emp中的数据将把清空,你select * from emp时看到表中是没有数据的,但表是存在的,这是跟drop的区别
-run

truncate和delete之间有什么区别


truncate和delete的主要区别:

1、delete是DML,执行delete操作时,每次从表中删除一行,并且同时将该行的的删除操作记录在redo和undo表空间中以便进行回滚(rollback)和重做操作,但要注意表空间要足够大,需要手动提交(commit)操作才能生效,可以通过rollback撤消操作。-delete

2、delete可根据条件删除表中满足条件的数据,如果不指定where子句,那么删除表中所有记录。

3、delete语句不影响表所占用的extent,高水线(high watermark)保持原位置不变。

4、truncate是DDL,会隐式提交,所以,不能回滚,不会触发触发器。

5、truncate会删除表中所有记录,并且将重新设置高水线和所有的索引,缺省情况下将空间释放到minextents个extent,除非使用reuse storage,。不会记录日志,所以执行速度很快,但不能通过rollback撤消操作(如果一不小心把一个表truncate掉,也是可以恢复的,只是不能通过rollback来恢复)。-run

6、对于外键(foreignkey )约束引用的表,不能使用 truncate table,而应使用不带 where 子句的 delete 语句。

7、truncatetable不能用于参与了索引视图的表。

扩展资料:

在速度上,一般来说truncate 》 delete。 

如果想保留表而将所有数据删除,如果和事务无关,用truncate就好。

如果和事务有关,或者想触发trigger,还是用delete。

参考资料:truncate (计算机函数)-百度百科

delete (编程语言)-百度百科


数据库做删除操作,delete与truncate的区别是什么


1.
delete可以配合where条件,只删除符合条件的数据;truncate不可以
2.
delete是dml语句,可以在事务中使用,每删除一条都会有相应的操作日志记录,可以
回滚
;truncate是ddl语句,执行后立刻生效,无法用在事务中,无法回滚操作
-delete