文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

ORA-01555: snapshot too old: rollback segment number string with name “string” too small

2023-11-04 22:46

关注

文档解释

ORA-01555: snapshot too old: rollback segment number string with name “string” too small

Cause: rollback records needed by a reader for consistent read are overwritten by other writers

Action: If in Automatic Undo Management mode, increase undo_retention setting. Otherwise, use larger rollback segments

ORA-01555: snapshot too old: rollback segment number string with name “string” too small 是一种常见的Oracle数据库错误,表示运行长事务所产生的回滚段空间不足导致请求的快照时间点超出了回滚段保存的信息时间点太旧而不可使用。

ORA-01555由于在执行长事务时,回滚段空间不足用而系统被迫更换回滚段,当事务回滚失败时报告该错误。最后事务可能失败,系统需要重新执行。

官方解释

提示ORA-1555的错误表明在当前SQL语句或事务中,由于回滚段的操作使回滚段太小,无法恢复表中当前版本之前的其他版本。

常见案例

1、ORA-1555错误通常在执行长时间会话或复杂操作时发生,可能已经不再需要(可以提交和在内部终止),但仍然可能需要回滚某些操作,而在这类情形中可能会遇到ORA-1555的错误。

2、尝试执行查询,该查询需要查询非常早的2016年数据,使用显式锁。这是最容易引发ORA-1555的问题。

正常处理方法及步骤

1、检查并增加回滚段的大小。检查并调整ORACLE_SID.initSID中的回滚段参数,比如:UNDO_RETENTION和ROLLBACK_SEGMENTS,以便增加存储空间大小。

2、增加排序缓冲区大小。检查并调整ORACLE_SID.initSID中的排序缓冲区参数,使其能有效减少排序操作,以减少消耗回滚段的存储空间。

3、调整事务的大小,尽量少的使用回滚段的时间。安排好事务的执行,在可能的情况下,尽可能细粒度的去分解事务,减少回滚段使用时间,以减少回滚段占用的存储空间大小。

4、检查和清理数据库锁表。检查以及清理锁表,以确保任务成功完成,锁表长期锁定可能会使长时间事务耗尽回滚段空间,并产生ORA-1555错误。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯