我从 Oracle 那里得到一个堆栈跟踪,说第 299 行有问题。没问题,我查看了有问题的包中的那一行,并说它是初始化块中的一行,将变量设置为 1,并且没有调用引发错误的过程。
根据堆栈跟踪中的行号,服务器正在执行的内容与我查看包源时看到的内容之间似乎存在不匹配。
我如何查看包:我使用 PL/SQL Developer 并在对象浏览器中单击包名称上的“查看 Pacakge”。当我在源代码管理中查看同一个包时,第 299 行的错误是有道理的(它是对失败的过程的调用)。
所以我的问题是:WTF 是怎么回事?当我向 Oracle 询问 pacakge 源时,为什么我得到的源代码似乎与堆栈跟踪行号不匹配?
(甲骨文10g)