Oracle数据库 ORA

Oracle数据库ORA-01555快照过旧是为什么?怎么解决?... Oracle数据库 ORA-01555 快照过旧是为什么?怎么解决? 展开
 我来答
创作者smf2yb289z
2019-08-19 · TA获得超过3962个赞
知道小有建树答主
回答量:3100
采纳率:33%
帮助的人:220万
展开全部
发生ORA-01555有以下几种原因:
(1).查询SQL执行时间过长,回滚段太小。
(2).系统频繁进行DML操作,导致UNDO循环复写很快。
(3).块清除(8i以后很少发生)
下图模拟了(1),(2)情况ORA-01555发生的过程
0:00
查询开始
0:01
另一个会话UPDATE块1000000,回滚信息记录在回滚段上。
0:01
update会话commit。回滚段仍在那里,但是会被复写。
1:00
查询仍在进行
在块200000上
。。。。。期间进行了大量的DML操作,不断向undo中写入
4:00
查询仍在进行
在块600000上。
4:01
UNDO已满,开始覆盖,将0:01写入的回滚段覆盖。
4:30
查询到1000000时
发现查询开始已经被修改了,进入回滚段试图找到那个块的撤销信息,从而得到一致读。这时发现需要的信息已经不存在,ORA-01555出现,查询失败。
(3)发生的情况是:下一个session在块修改后第一次访问它时,需要检查最后修改块的事务是否仍被激活,一旦确定没有激活就执行清除块操作。为了清除块,ORACLE需要访问前一事务的回滚段,但是发现该回滚段已经被复写,这时也会发生ORA-01555.
解决和预防的方法有:
(1).使用合适大小的事务,没有提交太频繁。
(2).增加更多的回滚段,延长undo区被复写的时间。
(3).降低查询的运行时间。(推荐做法)。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
苏州蓝晓生物科技有限公司_
2022-08-05 广告
苏州蓝晓生物科技有限公司。标准化核心产品:公司拥有完整的琼脂糖介质、葡聚糖介质、聚甲基丙烯酸酯介质生产线,年产分离介质50000L,产品质量稳定并达到国际领先水平。核心优势:公司核心技术人员拥有近二十年不同基质的基球开发和官能化的丰富技术经... 点击进入详情页
本回答由苏州蓝晓生物科技有限公司_提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式