出现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:快照过旧 异常。

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

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值