暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

ORA-01555 caused by SQL statement below (SQL ID

原创 丹丹 2024-07-31
206

在Oracle数据库种,比较常见的一个错误是ORA-01555。

报错如下:

我依据这个sql_id去找对应的sql,发现通常是如下类似的sql。

即程序的sql中嵌入一个具体的包含日期的条件,这个sql在执行的初期由于数据量较少,大概没有什么问题,但是一年两年数据越来越大,就会出现ORA-01555,即要查找的数据在UNDO里面已经找不到了。

示例如下:

SELECT * FROM TEST WHERE CREATED_TIME > '20230921001919';

针对这个问题,我通知相应的开发,做了如下类似的更改,这个问题就极大地减少了出现的频率。

SELECT * FROM TEST WHERE CREATED_TIME > SYSDATE -100;

ORA-01555 错误通常的原因有三种:

1. 不合理的 UNDO 设置;

2. 未优化的 SQL;

3. Out-of-row 方式存储的 LOB 段上 UNDO 保留区设置不合理。

比较常见的解决方法如下:

(1)、增加UNDO表空间大小;

(2)、增加undo_retention时间,默认只有15分钟;

(3)、优化出错的SQL,减少查询的时间;

(4)、避免频繁的提交。

最后修改时间:2025-09-30 10:55:52
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论