出现ORA-01555快照过旧的原因说明

出现ORA-01555快照过旧的原因说明

一般大部分人员都遇到过该报错信息,这里记录下这个oracle错误产生的最常见原因,以便后来参考

假设服务器 zw2上的一张表 t_imei_tmp001 里面有字段 ( id, info_id )。
现在有两个操作几乎同时进行,一个是查询、一个是更新该表。
这两个操作分别产生两个oracle进程,假设是 session_A 和 session_B。

这张表很大,查询时间也很长。
session_B 更新操作: update t_imei_tmp001 set info_id = 99999999 where id = 45230;
session_A 查询操作: select * from t_imei_tmp001 a order by id;

在 session_B 更新之前 oracle 会将更新之前的记录放入 回滚段(undo)中 (这里的数据可用于 rollback 操作) ,


在 session_A 还没有查询到 id= 45230 这条记录时,session_B已经 commit了,并且由于zw2数据库增删改


比较繁忙,此时回滚段中 id= 45230 这条数据由于commit后将被标志为过期(可被覆盖),可能早已经被其他事务产生的undo数据给覆盖了,


当 session_A 查询到 id= 45230 这条记录时,由于它是在更新之前查询的,理应查询更新之前的数据(数据库中读一致性原则),


但是现在表中的那条记录已经被更新了,这条记录版本不是原来被更新之前的版本。因此会报 ORA-01555:快照过旧 异常。

遇到这种问题,需要查看查询、或更新的语句是否有可优化的地方。 尽量减少更新的时间,或则一般报表中用查询生成中间表来代替更新操作。

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部