用于查找包的多级依赖项的脚本
Posted
技术标签:
【中文标题】用于查找包的多级依赖项的脚本【英文标题】:Script to find multi level dependencies of a package 【发布时间】:2014-01-17 13:26:01 【问题描述】:我有一个包,它引用了来自同一架构和其他架构的许多对象。我想找到包的所有依赖项。我只能从user_dependencies
获得第一级依赖项。 utldtree
也会给我依赖于我当前对象的对象。utldtree
也只给出相同模式中的引用对象。
当我试图在网上找到解决方案时,我遇到了以下链接 http://rodgersnotes.wordpress.com/2012/01/05/notes-on-deptree/ 在他提到的地方,他使用自己的脚本来查找对象的多级依赖关系。
你能帮我吗,如何处理这样一个脚本,它将为我们提供一个对象的多级依赖关系,(例如,如果包引用视图,那么我们的脚本应该提到视图和表/views 我们的视图建立在deptree
)
【问题讨论】:
【参考方案1】:在大多数情况下,您可以在 user_dependencies 上使用连接。
确定依赖关系
适用于任何 Oracle 用户的示例,因为 PUBLIC 已被授予对 user_dependencies 的选择访问权限:
select name
, type
, prior name
, prior type
from user_dependencies
start
with name='BUBS#MUNT_EENHEDEN'
and type='PACKAGE'
connect
by nocycle
name = prior referenced_name
and type = prior referenced_type
样本输出
Level 1: BUBS#MUNT_EENHEDEN PACKAGE
Level 2: BUBS_MUNT_EENHEDEN_V VIEW BUBS#MUNT_EENHEDEN PACKAGE
Level 3: BUBS#VERTALINGEN PACKAGE BUBS_MUNT_EENHEDEN_V VIEW
Level 4: ITGEN_LANGUAGES_V VIEW BUBS#VERTALINGEN PACKAGE
复杂场景
对于复杂的场景,我发现有必要直接在数据字典上使用自己的视图。仅当您知道自己在做什么以及想要支持的 RDBMS 版本时才这样做!例如,数据模型版本在数据字典中引入了重大变化。
示例:
create or replace force view itgen_object_tree_changes_r
as
select o_master.obj# ojt#
, o_master.name ojt_name
, o.mtime ojt_ref_mtime
, o.name ojt_ref_name
, o.owner# ojt_ref_owner#
, decode
( o.type#
, 0, 'NEXT OBJECT'
, 1, 'INDEX'
, 2, 'TABLE'
, 3, 'CLUSTER'
, 4, 'VIEW'
, 5, 'SYNONYM'
, 6, 'SEQUENCE'
, 7, 'PROCEDURE'
, 8, 'FUNCTION'
, 9, 'PACKAGE'
, 11, 'PACKAGE BODY'
, 12, 'TRIGGER'
, 13, 'TYPE'
, 14, 'TYPE BODY'
, 19, 'TABLE PARTITION'
, 20, 'INDEX PARTITION'
, 21, 'LOB'
, 22, 'LIBRARY'
, 23, 'DIRECTORY'
, 24, 'QUEUE'
, 28, 'JAVA SOURCE'
, 29, 'JAVA CLASS'
, 30, 'JAVA RESOURCE'
, 32, 'INDEXTYPE'
, 33, 'OPERATOR'
, 34, 'TABLE SUBPARTITION'
, 35, 'INDEX SUBPARTITION'
, 40, 'LOB PARTITION'
, 41, 'LOB SUBPARTITION'
, 42, nvl
( ( select 'REWRITE EQUIVALENCE'
from sys.sum$ s
where s.obj# = o.obj#
and bitand ( s.xpflags, 8388608 ) = 8388608 ), 'MATERIALIZED VIEW'
)
, 43, 'DIMENSION'
, 44, 'CONTEXT'
, 46, 'RULE SET'
, 47, 'RESOURCE PLAN'
, 48, 'CONSUMER GROUP'
, 51, 'SUBSCRIPTION'
, 52, 'LOCATION'
, 55, 'XML SCHEMA'
, 56, 'JAVA DATA'
, 57, 'EDITION'
, 59, 'RULE'
, 60, 'CAPTURE'
, 61, 'APPLY'
, 62, 'EVALUATION CONTEXT'
, 66, 'JOB'
, 67, 'PROGRAM'
, 68, 'JOB CLASS'
, 69, 'WINDOW'
, 72, 'WINDOW GROUP'
, 74, 'SCHEDULE'
, 79, 'CHAIN'
, 81, 'FILE GROUP'
, 82, 'MINING MODEL'
, 87, 'ASSEMBLY'
, 90, 'CREDENTIAL'
, 92, 'CUBE DIMENSION'
, 93, 'CUBE'
, 94, 'MEASURE FOLDER'
, 95, 'CUBE BUILD PROCESS'
, 'UNDEFINED'
)
ojt_ref_type
from sys.obj$ o
, ( /* All dependencies from the object if there are any. */
select distinct connect_by_root d_obj# obj#, dep.p_obj# obj_ref#
from sys.dependency$ dep
connect
by nocycle dep.d_obj# = prior dep.p_obj#
start
with dep.d_obj# in ( select obj.obj# from itgen_schemas_r sma, sys.obj$ obj where obj.owner# = sma.owner# )
union all /* Union all allowed, 'in' ignores duplicates. */
/* The object itself. */
select obj.obj#
, obj.obj#
from itgen_schemas_r sma
, sys.obj$ obj
where obj.owner# = sma.owner#
) deps
, sys.obj$ o_master
where o_master.obj# = deps.obj#
and o.obj# = deps.obj_ref#
--
-- View: itgen_object_tree_changes_r
--
-- Overview of dependencies between a master object and all objects used by it. It can be used to analyze the reason why a project version views must be recalculated.
--
-- Code (alias): ote_r
--
-- Category: Hardcoded.
--
-- Example:
--
-- The object 'X' is invalid, since 'Y' is invalid.
--
【讨论】:
user_dependencies
将仅提供第一级依赖项。我们无法正确获得多级依赖关系..!! @Guido
@dastan 是正确的。使用 connect by 你可以循环它。见样本。请注意,在较旧的 Oracle 版本上,您需要将 user_dependencies 内联为视图以允许 connect by 工作。
嗨@dastan 这有助于解决您的问题吗?如果不是,请在您的问题中添加不成功的内容。当答案对您有帮助时,您是否可以通过单击旁边的空心绿色复选标记来接受它?
我无法尝试您的解决方案,因为我无权访问系统文件。如果您可以在不使用系统文件的情况下提供解决方案,即非 dba 用户可以使用的解决方案,那可能会有所帮助
@dastan 感谢您的反馈。我了解您无法直接访问数据(这对开发人员来说很正常)。第一个示例已被一些文档扩展;那个适用于任何用户。这个答案对你有帮助吗?以上是关于用于查找包的多级依赖项的脚本的主要内容,如果未能解决你的问题,请参考以下文章