2MUCH

数据库无效对象

2022-05-14


数据库无效对象

背景:报“ORACLE存在无效对象,可能影响应用性能,评估是否重建对象”

概念

无效 PL/SQL 对象和不可用索引会对性能产生影响。无效 PL/SQL 对象必须先进行重编译,然后才能使用。这需要在执行尝试访问 PL/SQL 程序包、过程或函数的第一个操作之前花费一段编译时间。如果 PL/SQL 重编译未成功,,则操作会因发生错误而失败。优化程序会忽略不可用索引。如果 SQL 语句性能的好坏取决于已标记为不可用的索引,则只有重建索引才能改善性能。

如果查找到 INVALID 状态的 PL/SQL 对象,需要回答的第一个问题是“此对象曾经是 VALID 的吗?”应用程序开发人员常常会忘记清除不起作用的代码。如果 PL/SQL 对象因代码错误而无效,则除了纠正该错误之外,没有什么别的方法。如果该过程在过去曾经有效,最近才变为无效,则可选择以下两种方法解决这个问题:

1.不做任何处理。如果需要,大多数 PL/SQL 对象在调用时会自动重新编译。用户在对象重新编译时会经历短暂的延迟。(大多数情况下,这种延迟不十分明显。)

2.手动重新编译无效对象。

无效对象产生的原因

查找无效对象

执行用户:SYSTEM用户或其他有权限的用户

SQL> select owner, object_name, object_type
from dba_objects t
where status = 'INVALID'
order by t.owner,t.object_type;

或者

select owner, object_type, status, count(*)
from dba_objects
where status='INVALID'
group by owner, object_type, status
order by owner, object_type
col owner for a20;
col object_name for a32;
col object_type for a16
col status for a8
select owner, object_name, object_type, status
from dba_objects
where status='INVALID'
order by 1,2,3;

解决

重新编译失效的对象(以下步骤参考:https://developer.aliyun.com/article/34172?spm=5176.24320532.content1.1.1b6b12c2lTMMVr#/)

参考链接

查询无效对象结果的例子以及解决例子:

​ https://www.shuzhiduo.com/A/A7zg7WNWz4/#/

​ https://blog.csdn.net/weixin_39617318/article/details/116344253#/

​ https://blog.csdn.net/weixin_30661579/article/details/116439657#/