首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >ORA-01031:选择视图时权限不足

ORA-01031:选择视图时权限不足
EN

Stack Overflow用户
提问于 2008-09-26 16:47:52
回答 8查看 204.1K关注 0票数 30

当我尝试执行包含来自不同模式的表的视图时,抛出ORA-001031权限不足。这些表对创建视图的架构具有execute权限。如果我执行视图的SQL语句,它就可以工作。我遗漏了什么?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2008-09-26 16:53:33

作为表所有者,您需要向运行SELECT语句的用户授予对底层表的SELECT访问权限。

代码语言:javascript
复制
grant SELECT on TABLE_NAME to READ_USERNAME;
票数 19
EN

Stack Overflow用户

发布于 2008-09-26 18:47:16

最后我让它起作用了。Steve的答案是正确的,但并不适用于所有情况。当从第三个模式执行该视图时,它会失败。为此,您必须添加授权选项:

代码语言:javascript
复制
GRANT SELECT ON [TABLE_NAME] TO [READ_USERNAME] WITH GRANT OPTION;

这样,[READ_USERNAME]还可以将视图的select权限授予另一个模式

票数 37
EN

Stack Overflow用户

发布于 2009-07-15 18:27:12

问:什么时候需要“带授权选项”?

A.当您从第三个模式执行视图时。

示例: schema DSDSW有一个名为view_name的视图

代码语言:javascript
复制
a) that view selects from a table in another schema  (FDR.balance)
b) a third shema  X_WORK  tries to select  from that view

典型的授权:将dsdw.view_name上的select授权给dsdw_select_role;将dsdw_select_role授权给罗斯福;

但是: fdr从dsdw.view_name获取select count(*);第1行错误: ORA-01031:权限不足

发放奖助金:

代码语言:javascript
复制
grant select on fdr.balance to dsdw with grant option;

现在fdr: select count(*) from dsdw.view_name;5行

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/140643

复制
相关文章

相似问题

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