有没有方法阻止回滚?

日期: 2009-05-21 作者:Brian Peasland翻译:April 来源:TechTarget中国 英文

问:我的表有10个分区。每个分区都有100万个行。我想删除分区1里rid=1的一些行。但是进行这一操作需要花费很长、很长的时间,所以我终止了会话。

现在我的数据库出现了事物回滚,所有的行都被删除了。   我的疑问就是:有没有一种方法可以阻止事务回滚?如果我马上关闭,我推测将要花费很长的时间。如果我关闭中途失败,当我重新启动数据库时,是不是需要一段很长的时间来恢复?   我并不在乎数据库是不是已经删除了。我需要解决“”alter table xyz nologging”的方法而不是触发“”ORA-00054 resource busy …”   答:……

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

TechTarget中国

电子邮件地址不会被公开。 必填项已用*标注

敬请读者发表评论,本站保留删除与本文无关和不雅评论的权力。

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

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

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

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

作者

Brian Peasland
Brian Peasland

Techtarget旗下Searchoracle网站的资深专家,有16年IT行业经验、计算机科学硕士、专攻数据库方向,曾担任系统管理员等职。此外,他还获Oracle 7.3、8和8i的OCP数据库管理员证书,目前为SGT Inc.公司首席DBA。

翻译

April
April

相关推荐