用于查找包的多级依赖项的脚本

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 感谢您的反馈。我了解您无法直接访问数据(这对开发人员来说很正常)。第一个示例已被一些文档扩展;那个适用于任何用户。这个答案对你有帮助吗?

以上是关于用于查找包的多级依赖项的脚本的主要内容,如果未能解决你的问题,请参考以下文章

具有相同依赖项的不同版本的 nuget 包的 azure 函数

如何处理将作为另一个包的依赖项的命名空间包

如何创建具有基本依赖项的 deb 包?

用于仅测试依赖项的 Gradle 变体感知依赖项管理

重新创建没有依赖项的GitHub项目(Java)

哪些 NPM CLI 命令可用于更新依赖项的依赖项?