`
sundful
  • 浏览: 1245188 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

ORA-01720

阅读更多
对我来说权限方面是本人最反感的部分之一,但作为开发DBA也是本人比较常遇到的问题,今天在GRANT SELECT ON 某个view时又出现了ORA-01720的问题,ORACLE的解决方法是使用WITH GRANT OPTION,于是自己也做了个实验在公司的测试环境模拟了一下:

--------------------------------------------------------------------------------------------------
SQL> conn own_user/tom@dwteam
SQL> create table FACT_1 as select * from v$log;

Created.

SQL> conn main_user/tom@dwteam
SQL> create synonym FACT_1 on own_user.FACT_1;

Created.

SQL> create view fact_1_view AS SELECT * from FACT_1;

Created.

SQL> conn dba_user/tom@dwteam
Connected.

SQL> revoke select on own_user.FACT_1 from main_user;

Revoke succeeded.

SQL> grant select on own_user.FACT_1 to main_user;

Grant succeeded.


--- Check grant to rstmt without grant option:
SQL> conn main_user/tom@dwteam
Connected.
SQL> GRANT SELECT ON FACT_1 to etl_user;
GRANT SELECT ON FACT_1 to etl_user
                *
ERROR at line 1:
ORA-01031: insufficient privileges


SQL> GRANT SELECT ON fact_1_view to etl_user;
GRANT SELECT ON fact_1_view to etl_user
                *
ERROR at line 1:
ORA-01720: grant option does not exist for 'own_user.FACT_1'


SQL> conn dba_user/tom@dwteam
Connected.

--- Add "with grant option"
SQL> grant select on own_user.FACT_1 to main_user with grant option;

Grant succeeded.

SQL> conn main_user/tom@dwteam
Connected.
SQL> GRANT SELECT ON FACT_1 to etl_user;

Grant succeeded.

SQL> GRANT SELECT ON fact_1_view to etl_user;

Grant succeeded.


--- Can we direct give privilege to etl_user?
1. NO
--- grant select priv on select directly to etl_user:
SQL> conn dba_user/tom@dwteam
Connected.
SQL> grant select on own_user.FACT_1 to etl_user;

Grant succeeded.

SQL> conn main_user/tom@dwteam
Connected.
SQL> GRANT SELECT ON fact_1_view to etl_user;
GRANT SELECT ON fact_1_view to etl_user
                *
ERROR at line 1:
ORA-01720: grant option does not exist for 'own_user.FACT_1'

2. How? -- 1) Create view under fact_1_view, 2) give privilege with grant option;
分享到:
评论

相关推荐

    ora-01720 授权选项对于'xxxx'不存在的解决方法

    ### ora-01720 授权选项对于'xxxx'不存在的解决方法 #### 背景介绍 在Oracle数据库管理中,权限管理和授予是非常重要的一个环节。它确保了数据的安全性和访问控制的有效性。然而,在进行权限授予时可能会遇到各种...

    ORACLE ORA-00132 ORA-00214

    ### Oracle 错误 ORA-00132 和 ORA-00214 解析及处理 #### 一、错误概述 在Oracle数据库管理过程中,遇到ORA-00132和ORA-00214这类错误时,往往意味着数据库配置或启动过程中出现了问题。下面将对这两个错误进行...

    使用工具IMPDP导入数据时ORA-39002、ORA-39070错误排查

    在使用Oracle Data Pump工具IMPDP(Import Data Pump)进行数据导入的过程中,可能会遇到ORA-39002和ORA-39070等错误。本文将针对这些错误的排查方法进行详细介绍,帮助用户理解问题的原因及解决策略。 ### 错误...

    Drop goldengate用户时报ORA-00604 ORA-20782 ORA-06512问题解决

    ### 解决Drop Goldengate 用户时报ORA-00604 ORA-20782 ORA-06512问题 #### 一、问题背景与现象 在进行Oracle数据库管理过程中,经常会遇到需要删除用户的场景。当尝试执行`drop user goldengate cascade;`命令时,...

    Oracle 11gr2连Oracle 19c 报ORA-28040 ORA-01017解决方法.pdf

    Oracle数据库不同版本间的客户端与服务端的连接问题通常涉及到安全和兼容性配置,这篇文章主要讲述了在Oracle 11g R2客户端尝试连接Oracle 19c服务端时,遇到了两个特定的错误:ORA-28040和ORA-01017,以及如何解决...

    ora-00604错误解决方法

    ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法ora-00604 错误 解决 方法

    ORA-04052p5731178_92080_WINNT.zip

    ORA-00604: 递归SQL层1出现错误 ORA-03106: 致命的双工通信协议错误 ORA-02063: 紧接着line(源于dblink) 以及 ORA-04052: 在查找远程对象时出错 ORA-00604: 递归SQL层1出现错误 ORA-03120: 双工转换例行程序:整数...

    oracle网络配置(listener_ora-sqlnet_ora-tnsnames_ora).mht

    oracle网络配置(listener_ora-sqlnet_ora-tnsnames_ora).mht

    Oracle12cRAC数据库 出现ora-12520, ora-12516

    ### Oracle12cRAC数据库出现ora-12520, ora-12516问题解析 #### 一、问题概述 在使用Oracle12cRAC(Real Application Clusters)数据库的过程中,可能会遇到客户端连接时出现ora-12520或ora-12516错误的问题。这两...

    关于创建oracle 连接时报以下错误,ORA-01017 ORA-02063

    在创建Oracle数据库连接时遇到的错误ORA-01017和ORA-02063涉及到用户认证问题以及Oracle数据库版本之间的差异处理。ORA-01017错误表示用户名或密码无效,登录被拒绝,而ORA-02063则通常表示在Oracle数据库之间进行...

    如何处理错误ORA-29275:部分多字节字符

    ### 如何处理错误ORA-29275:部分多字节字符 #### 问题背景与描述 在Oracle数据库操作过程中,用户可能会遇到一个特定的错误提示——ORA-29275:部分多字节字符。这一错误通常出现在执行查询`SELECT * FROM V$...

    oracle重启报错ORA-00702解决办法

    然而,在日常运维过程中,我们可能会遇到各种错误,比如“ORA-00702”就是其中之一。这个错误通常在尝试重启Oracle数据库服务时出现,意味着数据库实例在启动过程中遇到了问题。本文将详细介绍如何在Windows和Linux...

    Oracle 10g启动后报ORA-16038错误的解决方法

    ### Oracle 10g启动后报ORA-16038错误的解决方法 #### 错误概述 在启动Oracle 10g数据库时遇到ORA-16038错误,该错误通常与归档日志操作有关。具体错误信息为: ``` ORA-16038: log 1 sequence #230 cannot be ...

    离线误删空间文件导致的ORA-01033及ORA-01145问题的解决办法

    ### 离线误删空间文件导致的ORA-01033及ORA-01145问题的解决办法 #### 概述 在Oracle数据库管理过程中,偶尔会遇到因误操作导致的数据文件出现问题的情况,例如误删除数据文件或者数据文件损坏等。这些问题可能会...

    Oracle_ORA-12518故障_处理

    ### Oracle ORA-12518 故障处理 #### 概述 在Oracle数据库管理过程中,遇到ORA-12518错误是较为常见的问题之一。此错误通常发生在客户端试图连接到数据库服务器的过程中,当监听器无法将客户端连接顺利地移交给...

    ORA-12541 TNSno listener 的解决方案

    ORA-12541 TNSno listener 的解决方案 ORA-12541 TNSno listener 的解决方案

    OGG之ORA-01403案例

    OGG 之 ORA-01403 案例分析 本文将对 OGG 之 ORA-01403 案例进行详细的分析,包括出现错误的原因、解决方法、handlecollisions 参数的解析和使用注意事项等。 一、错误原因分析 OGG 之 ORA-01403 案例中,出现了...

    ora-01460 错误原因分析

    ### ORA-01460 错误原因分析 #### 概述 在Oracle数据库操作过程中,可能会遇到ORA-01460错误,该错误全称为“ORA-01460: 转换请求无法实现或不合理”。这一错误通常发生在数据类型转换或者与操作系统之间的数据...

Global site tag (gtag.js) - Google Analytics