关于创建视图遇到ORA-01031错误信息,请参考我以前整理的一篇文章Create view failed with ORA-01031:insufficient privileges,本来以为我那篇文章已经已经囊括了很多案例,但是今天遇到一个特殊案例,折腾了我比较久。下面通过几个例子来演示一下遭遇ORA-01031的来龙去脉。

在测试环境准备两个用户dm、ods并授予一定的权限,准备好我们演示的案例。

SQL> show user;

USER is "SYS"

 

SQL> create user dm identified by dm;

 

User created.

 

SQL> create user ods identified by ods;

 

User created.

 

SQL> grant connect , resource to dm;

 

Grant succeeded.

 

SQL> grant create view to dm;

 

Grant succeeded.

 

SQL> grant connect , resource to ods;

 

Grant succeeded.

案例1: 将VIEW的SELECT权限授予其它用户时,遭遇ORA-01720错误

SQL> conn ods/ods

Connected.

 

SQL> create table department

  2  (

  3      dept_id        number(10)  ,

  4      dept_name      varchar2(12) 

  5  );

 

Table created.

 

SQL> grant select on department to dm;

 

Grant succeeded.

 

SQL> conn dm/dm

Connected.

 

 

SQL> create table employee

  2  (

  3      employee_id    number(10)  ,

  4      employee_name  varchar2(32),

  5      dept_id        number(10)

  6  );

 

Table created.

 

SQL> show user

USER is "DM"

 

SQL> create table employee

  2  (

  3      employee_id      number(10)  ,

  4      employee_name    varchar2(32),

  5      dept_id          number(10)

  6  );

 

Table created.

 

SQL> select * from v_test;

 

no rows selected

 

SQL> grant select on dm.v_test to ods;

grant select on dm.v_test to ods

                   *

ERROR at line 1:

ORA-01720: grant option does not exist for 'ODS.DEPARTMENT'

 

出现这个错误,是因为用户ods将表DEPARTMENT的SELECT权限授予了用户dm,而dm将试图v_test的查询权限授予ods时,也试图将表DEPARTMENT授予用户ods,但是dm并没有这个权限(是不是很绕口),其实解决这个问题很简单,即在授权时要使用WITH GRANT OPTION,如下所示即可解决:

SQL> conn ods/ods 

Connected.

 

SQL> grant select on department to dm with grant option;

 

Grant succeeded.

 

SQL> conn dm/dm;

Connected.

 

SQL> grant select on dm.v_test to ods;

 

Grant succeeded.

 

SQL> conn ods/ods

Connected.

 

SQL> select * from dm.v_test;

 

no rows selected

案例2: 将VIEW授权给其它用户(sys账号下),查询时遭遇ORA-01031: insufficient privileges

SQL> show user;

 

USER is "ODS"

 

SQL> create or replace function get_deptcode( departname varchar2) return varchar2

  2  as

  3  dept_code varchar2(2);

  4  begin

  5     select substr(departname,1,1) into dept_code from dual;

  6     return dept_code;

  7  end;

  8  /

 

Function created.

 

SQL> grant execute on get_deptcode to dm;

 

Grant succeeded.

 

SQL> conn dm/dm

Connected.

 

SQL> create or replace view v_test

  2  as

  3     select e.employee_id

  4           ,e.employee_name

  5           ,(select ods.get_deptcode(d.dept_name) from dual) dept_code

  6     from employee e

  7     inner join ods.department d on e.dept_id =d.dept_id;

 

View created.

 

SQL> select * from v_test;

 

no rows selected

以sys登录授权ods拥有查询视图的权限,之所以用sys执行授权,而不用对应账号dm,是因为我发布脚本时,一般都用sys账号发布,结果就遭遇了比较隐秘的ORA-01031错误。

SQL> conn sys as sysdba

Enter password: 

Connected.

 

SQL> grant select on dm.v_test to ods;

 

Grant succeeded.

 

SQL> conn ods/ods

 

Connected.

 

SQL> select * from dm.v_test;

select * from dm.v_test

                 *

ERROR at line 1:

ORA-01031: insufficient privileges

如果以dm账号登录,将视图v_test的权限授予给ods,就能发现这个错误,而以sys账号操作,反而隐藏了该错误。如下所示

SQL> conn dm/dm

Connected.

 

SQL> grant select on v_test to ods;

grant select on v_test to ods

                *

ERROR at line 1:

ORA-01720: grant option does not exist for 'ODS.GET_DEPTCODE'

 

 

SQL> conn ods/ods

 

Connected.

 

SQL> grant execute on ODS.GET_DEPTCODE to dm with grant option;

 

Grant succeeded.

 

SQL> conn dm/dm

 

Connected.

 

SQL> grant select on v_test to ods;

 

Grant succeeded.

GRANT/SELECT View时的遭遇ORA-01720和ORA-01031错误的更多相关文章

  1. 关于SubSonic3.0插件使用SqlQuery或Select查询时产生的System.NullReferenceException异常修复

    早上在编写执行用例时,突然爆异常System.NullReferenceException: 未将对象引用设置到对象的实例 执行代码:

  2. Android自定义View研究--View中的原点坐标和XML中布局自定义View时View触摸原点问题

    这里只做个汇总~.~独一无二 文章出处:http://blog.csdn.net/djy1992/article/details/9715047 Android自定义View研究--View中的原点坐 ...

  3. 直接添加viewController中的view时的注意事项

    直接添加viewController中的view时需要注意一个问题,比如: MyTestViewController *vc = [MyTestViewController new]; [self.v ...

  4. MySQL实战 | 01-当执行一条 select 语句时,MySQL 到底做了啥?

    原文链接:当执行一条 select 语句时,MySQL 到底做了啥? 也许,你也跟我一样,在遇到数据库问题时,总时茫然失措,想重启解决问题,又怕导致数据丢失,更怕重启失败,影响业务. 就算重启成功了, ...

  5. scroll或是其子类被添加进view时,界面自动上移

    开发中经常会遇到ViewController添加scroll或是其子类被添加进controller.view时,scroll会自动下移大概64像素 解决: self.edgesForExtendedL ...

  6. oracle中的listener.ora和tnsnames.ora

    一.oracle的客户端与服务器端 oracle在安装完成后服务器和客户端都需要进行网络配置才能实现网络连接.    服务器端配置监听器,客户端配置网络服务名. 服务器端可配置一个或多个监听程序 . ...

  7. oracle: listener.ora 、sqlnet.ora 、tnsnames.ora的配置及例子

    1.解决问题:TNS或者数据库不能登录.      最简单有效方法:使用oracle系统提供的工具 netca 配置(把原来的删除掉重新配置)     $netca  2.然而,仍有疑问:如何指定'l ...

  8. oracle三个连接配置文件 listener.ora、sqlnet.ora、tnsnames.ora

    关于PLSQL连接ORACLE配置字符串 首先要讲一下下面的一些知识 1.ORACLE_SID:(ORACLE SYSTEM IDENTIFIER) Oracle实例是由SGA和一组后台进程组成的,实 ...

  9. oracle错误(ORA:12154 ORA:01034 和 ORA:27101 ORA-18008 ORA-01081)

    按照正常操作流程,启动项目,发现项目报错,原因是连接不上oracle数据库, PLSQL连接时报错,错误码  ORA:12154 无法解析指定的连接标识符 第一次,遇到这个错误,在网上找了资料都是需要 ...

随机推荐

  1. 1Z0-053 争议题目解析684

    1Z0-053 争议题目解析684 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 684.Your database is running in ARCHIVELOG mode. ...

  2. CSS 巧用 :before和:after

    前几天的晚上较全面的去看了下css的一些文档和资料,大部分的样式运用都没什么大问题了,只是有些许较陌生,但是也知道他们的存在和实现的是什么样式.今天主要想在这篇学习笔记中写的也不多,主要是针对:bef ...

  3. Spring整合Ehcache管理缓存

    前言 Ehcache 是一个成熟的缓存框架,你可以直接使用它来管理你的缓存. Spring 提供了对缓存功能的抽象:即允许绑定不同的缓存解决方案(如Ehcache),但本身不直接提供缓存功能的实现.它 ...

  4. 一个简单的Webservice的demo,简单模拟服务

    前段时间一直在学习WCF,匆匆忙忙的把<WCF全面解析>和<WCF服务编程>看了一遍,好多东西都不是很懂,又听了一下WCF分布式开发的网络教程,算是马马虎虎的明白点了.回顾了一 ...

  5. JConsole远程连接配置

    JConsole远程连接还是有一点坑的.这里记录一下配置过程,好记性不如烂笔头. 1.在远程机的tomcat的catalina.sh中加入配置: JAVA_OPTS="$JAVA_OPTS ...

  6. Git GUI下载远程源代码简单使用介绍

    学习编程,适当的时候弄些开源项目的源代码来学习实践,对技术是很有帮助的.如果学习.NET.C#的话,codeplex上面有许多不错的源代码,推荐一个ASP.ENT的:HoverTree http:// ...

  7. angularjs SyntaxError: Unexpected token  in JSON at position 0

    使用NodeJs读取json格式的文件,转换成对象时报错 :SyntaxError: Unexpected token in JSON at position 0,这个问题查了两三个小时,记录一下解决 ...

  8. 服务器Config文件不能查看的问题

      由于某种需求,需要从IIS发布的服务中下载扩展名为config的文件,但是发布文件后,在浏览器无法查看文件.根据反馈的的错误提示,大致说config属于配置文件,处于安全考虑,不能随便浏览. 如果 ...

  9. Unity3D 5.x 交互功能 - 光线投射、碰撞设置

    1,光线投射碰撞:第一人称视线在预置范围内(如3米)和看到的物体发生碰撞 ① 检测光线投射碰撞的脚本添加在第一人称FPSController上 #pragma strict private var c ...

  10. Codeforces Round #376A (div2)

    Night at the Museum 题意: 有一个转盘,26个英文字母均匀分布在转盘边缘,转针初始位置在字母a,每次只能转动到相邻的字母,然后输入一个由26个字母组成的字符串(最长100),不复位 ...