文档解释
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错误。