首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何在Oracle中查找对象的所有者?

如何在Oracle中查找对象的所有者?
EN

Stack Overflow用户
提问于 2009-06-04 04:47:01
回答 5查看 164.2K关注 0票数 20

我想查找表的外键,但可能有多个用户/模式具有同名的表。如何找到当前登录的用户正在查看的内容?有没有一个函数可以给它的所有者呢?如果有公共同义词怎么办?

EN

回答 5

Stack Overflow用户

发布于 2017-03-07 06:37:54

当我在Googling上搜索如何在Oracle中找到表的所有者时,我发现这个问题是最好的结果,所以我想我应该提供一个表特定的答案,以方便其他人。

要查找Oracle DB中特定表的所有者,请使用以下查询:

代码语言:javascript
复制
select owner from ALL_TABLES where TABLE_NAME ='<MY-TABLE-NAME>';
票数 5
EN

Stack Overflow用户

发布于 2009-06-03 21:21:03

有趣的问题-我不认为有任何Oracle函数可以做到这一点(几乎就像Unix中的“哪个”命令),但您可以通过以下方式获得名称的解析顺序:

代码语言:javascript
复制
select * from 
(
 select  object_name objname, object_type, 'my object' details, 1 resolveOrder 
  from user_objects
  where object_type not like 'SYNONYM'
 union all
 select synonym_name obj , 'my synonym', table_owner||'.'||table_name, 2 resolveOrder
  from user_synonyms
 union all
 select  synonym_name obj , 'public synonym', table_owner||'.'||table_name, 3 resolveOrder
  from all_synonyms where owner = 'PUBLIC'
)
where objname like upper('&objOfInterest')
票数 2
EN

Stack Overflow用户

发布于 2009-06-03 21:27:53

要在Oracle会话中查找当前用户的名称,请使用USER函数。

请注意,约束的所有者、包含外键的表的所有者以及被引用表的所有者可能都不同。这听起来像是你感兴趣的表所有者,在这种情况下,这应该是你想要的:

代码语言:javascript
复制
select Constraint_Name
from All_Constraints
where Table_Name = 'WHICHEVER_TABLE'
  and Constraint_Type = 'R' and Owner = User;
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/947140

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档