SQL中truncate table和oracle deletee的区别

一章 关于Palm 1 第二章 建立一个应用程序 8 第三章 文本框中的乐趣 20 第四章 窗体的编程 37 第五章 数据库 54 第六章 ...

十个c语言案例 (1)贪吃蛇 (2)五子棋游戏 (3)电话薄管理系统 (4)计算器 (5)万年历 (6)电子表 (7)客户端和服务器通信 (8)潜艇大战游戏 (9)鼠标器程序 (10)手机通讯录系统

(1)oracle deleteE语句执行删除的过程是每次從表中删除一行并且同时将该行的删除操作作为事务记录在日志中保存以便进行进行回滚操作。

   TRUNCATE TABLE 则一次性地从表中删除所有的数据并不紦单独的删除操作记录记入日志保存删除行是不能恢复的。并且在删除的过程中不会激活与表有关的删除触发器执行速度快。

(2)表囷索引所占空间

(6)truncate与不带where的oracle deletee :只删除数据,而不删除表的结构(定义)drop语句将删除表的结构被依赖的约束(constrain),触发器(trigger)索引(index);依赖于该表的存储过程/函数将被保留但其状态会变为:invalid。

(9)在没有备份情况下谨慎使用 drop 与 truncate。要删除部分数据行采用oracle deletee且注意结合where来约束影响范圍回滚段要足够大。要删除表用drop;若想保留表而将表中数据删除如果于事务无关,用truncate即可实现如果和事务有关,或老师想触发trigger,还是用oracle deletee

(11) TRUNCATE TABLE 删除表中的所有行,但表结构及其列、约束、索引等保持不变新行标识所用的计数值重置为该列的种子。如果想保留标识计数值请改用 oracle deleteE。如果要删除表定义及其数据请使用 DROP TABLE 语句。 

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

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

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

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

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

1、drop是DDL会隐式提交,所以不能回滚,不会触发触发器

2、drop语句删除表结构及所有数据,并将表所占用的空间全部释放

3、drop语句将删除表的结构所依賴的约束,触发器索引,依赖于该表的存储过程/函数将保留,但是变为invalid状态

2、在使用drop和truncate时一定要注意,虽然可以恢复但为了减少麻烦,还是要慎重

3、如果想删除部分数据用oracle deletee,注意带上where子句回滚段要足够大;

   如果想保留表而将所有数据删除,如果和事务无关用truncate即可;

我要回帖

更多关于 oracle delete 的文章

 

随机推荐