本文目录
oracle truncate与delete的区别
1、在功能上,truncate是清空一个表的内容,它相当于delete from table_name。
2、delete是dml操作,truncate是ddl操作;因此,用delete删除整个表的数据时,会产生大量的roolback,占用很多的rollback segments, 而truncate不会。
3、在内存中,用delete删除数据,表空间中其被删除数据的表占用的空间还在,便于以后的使用,另外它是“假相”的删除,相当于windows中用delete删除数据是把数据放到回收站中,还可以恢复,当然如果这个时候重新启动系统(OS或者RDBMS),它也就不能恢复了!而用truncate清除数据,内存中表空间中其被删除数据的表占用的空间会被立即释放,相当于windows中用shift+delete删除数据,不能够恢复!
4、truncate 调整high water mark 而delete不;truncate之后,TABLE的HWM退回到 INITIAL和NEXT的位置(默认)delete 则不可以。
5、truncate 只能对TABLE,delete 可以是table,view,synonym。
6、TRUNCATE TABLE 的对象必须是本模式下的,或者有drop any table的权限 而 DELETE 则是对象必须是本模式下的,或被授予 DELETE ON SCHEMA.TABLE 或DELETE ANY TABLE的权限。
7、在外层中,truncate或者delete后,其占用的空间都将释放。
8、truncate和delete只删除数据,而drop则删除整个表(结构和数据)。
扩展资料
Oracle Database,又名Oracle RDBMS,或简称Oracle。是甲骨文公司的一款关系数据库管理系统。它是在数据库领域一直处于领先地位的产品。可以说Oracle数据库系统是目前世界上流行的关系数据库管理系统,系统可移植性好、使用方便、功能强,适用于各类大、中、小、微机环境。它是一种高效率、可靠性好的 适应高吞吐量的数据库解决方案。
oracle数据库怎么清空
我觉得还是概念不清析,问题不太明白呀。所果只是简单的清空表的话,还是很容易的。drop table TABLE_NAME ; //连表结构都删了。要是清空内容,留着表结构,就是:truncate tablename; // 就可以了。如果是数据库表文件要删的话,就不和你说了。
oracle 11g 清空数据库指定用户下表内的数据
清空数据分三种。
1、用truncate语句删除(直接清空表内数据,并释放空间)。
语法:
truncate table 表名;
2、用drop语句删除(不仅清空表内数据,并且删除表结构)。
语法:
drop table 表名;
3、用delete语句删除(可直接删除表内数据,也可以按条件删除表内数据,但执行后不释放空间,如果数据量大,执行较慢)。
语法:
delete from 表名;--删除表内所有数据delete from 表名 where 条件;--按条件删除表内数据
oracle 表数据太多怎么删除
在ORACLE表中删除数据通常有两种方法:一种是使用delete,一种是使用truncate。 delete 优点:1、可以增加WHERE条件来进行选择性删除。 2、可以通过rollback进行回滚。 缺点:1、速度较慢。 truncate 优点:1、速度很快。 缺点:1、不能加条件删除。 2、无法通过rollback进行数据回滚。