创建此问题的方案:
我们有一个包是另一个包的依赖,有时对"父"包进行更改会导致依赖包变为无效,但有时却不会.
它之前让我们感到惊讶.
简单地理解导致失效的原因是非常有用的,因此我可以预测/计划失效.
更改包依赖的任何对象(例如表,视图,触发器,其他包)将自动将包标记为无效.正如上面的tuinstoel所说,Oracle在第一次使用时足够聪明,可以重新编译软件包.
如果您担心这一点,每次进行架构更改(例如表,视图,触发器,过程)时,运行一个DBMS_UTILITY.compile_schema
(或让DBA执行此操作).这将强制编译所有包,并让您知道在找到错误之前,或者是否有错误.
或者,您可以查询下表以查看您拥有的依赖项
select * from dba_dependencies where name = 'YOUR_PACKAGE' and referenced_owner = 'ANYUSER' --- Comment this out if you are looking for yourself and owner = USER --- Or can be set to any user
这将显示所有依赖项.对于您的对象查询user_dependencies.