What Situations Cause Oracle Packages to Become Invalid?(哪些情况会导致 Oracle 软件包无效?)
问题描述
产生这个问题的场景:
我们有一个包是另一个包的依赖项,有时对父"包进行更改会导致依赖包无效,但有时不会.
We have a package that is a dependency of another package, sometimes making changes to the "parent" package causes the dependent package to become invalid, but sometimes it doesn't.
之前它让我们大吃一惊.
It has caught us by surprise before.
简单地了解导致失效的原因非常有用,这样我就可以预测/计划它.
It would be very useful to simply understand what causes invalidation so I could predict/plan for it.
推荐答案
更改包所依赖的任何对象(例如表、视图、触发器、其他包)将自动将包标记为无效.正如上面的 tuinstoel 所指出的,Oracle 足够聪明,可以在第一次使用包时重新编译它.
Changing anything object that a package relies upon (e.g. tables, views, triggers, other packages) will automatically mark the package as invalid. As tuinstoel notes above, Oracle is smart enough to recompile the package when it is first used.
如果您对此感到担心,则每次进行架构更改(例如表、视图、触发器、过程)时,请运行 DBMS_UTILITY.compile_schema
(或让您的 DBA 执行此操作).这将强制编译所有包,并让您知道哪里或是否有错误,然后才能找到它们.
If you are concerned about this, every time you make schema changes (e.g. tables, views, triggers, procedures), run a DBMS_UTILITY.compile_schema
(or have your DBA do it). This will force compile all the packages and let you know where, or if, there are errors before you find them the hard way.
这篇关于哪些情况会导致 Oracle 软件包无效?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:哪些情况会导致 Oracle 软件包无效?


基础教程推荐
- 无法在 ubuntu 中启动 mysql 服务器 2021-01-01
- SQL Server 中单行 MERGE/upsert 的语法 2021-01-01
- Sql Server 字符串到日期的转换 2021-01-01
- SQL Server:只有 GROUP BY 中的最后一个条目 2021-01-01
- SQL Server 2016更改对象所有者 2022-01-01
- 在 VB.NET 中更新 SQL Server DateTime 列 2021-01-01
- 如何在 SQL Server 的嵌套过程中处理事务? 2021-01-01
- 将数据从 MS SQL 迁移到 PostgreSQL? 2022-01-01
- 使用pyodbc“不安全"的Python多处理和数据库访问? 2022-01-01
- ERROR 2006 (HY000): MySQL 服务器已经消失 2021-01-01