有没有方法阻止回滚?

 
   | |

导读:专家认为不能阻止系统回滚一个终止事务。既然已经终止了会话,那事务就终止了并且系统也就只能回滚你更改的一些内容……

关键词:Oracle Oracle错误 Oracle事务回滚

正在加载数据... 【TechTarget中国原创】我的表有10个分区。每个分区都有100万个行。我想删除分区1里rid=1的一些行。但是进行这一操作需要花费很长、很长的时间,所以我断开了会话。现在我的数据库出现了事物回滚,所有的行都被删除了。

【TechTarget中国原创】问:我的表有10个分区。每个分区都有100万个行。我想删除分区1里rid=1的一些行。但是进行这一操作需要花费很长、很长的时间,所以我终止了会话。现在我的数据库出现了事物回滚,所有的行都被删除了。

  我的疑问就是:有没有一种方法可以阻止事务回滚?如果我马上关闭,我推测将要花费很长的时间。如果我关闭中途失败,当我重新启动数据库时,是不是需要一段很长的时间来恢复?

  我并不在乎数据库是不是已经删除了。我需要解决“"alter table xyz nologging”的方法而不是触发“"ORA-00054 resource busy ..."

  答:你不能阻止系统回滚一个终止事务。既然你已经终止了会话,那事务就终止了并且系统也就只能回滚你更改的一些内容。系统不会替你决定要保留哪些、删除哪些中止事务。所以它就会回滚。即使你已经关闭了数据库,而且还进行了备份,在数据库启动后它也仍然会出现回滚。你只需要等待它完成,一旦它完成了事务回滚,你就不会再出现ORA-00054错误。

 
查看全文
 
 
 
 
 

Oracle错误

 
Oracle通常将没有引号的标识符转换成大写键盘的,在提交查询时你必须给列名加入双引号以避免出现错误。
 
在Oracle中,CLOB列包含了分隔的10位代码,如何避免重复的代码是一件比较麻烦的事,专家给出了三种解决方法,你可以根据自身情况进行选择。
 
在Windows 2003操作系统下安装了Oracle 8i数据库软件,使用的时候发生Ora-1067错误,出现这一问题的原因是什么,Oracle专家给出了解释。
 
如何在触发器内部建立一个索引,专家说如果DML是EXECUTE IMMEDIATE语句的一部分,你就可以在触发器中执行DML。
 
在进行Oracle实例维护时出现内存分配问题,导致无法启动新连接,正在运行的会话很慢,专家将给出解决方案。
 

登录TechTarget中国

关闭
本服务仅向TechTarget中国的会员开放,请登录或立即免费注册
电子邮件地址:
请输入您的电子邮件地址
密码:
下次自动登录