网站首页 > 技术文章 正文
运维反馈部分客户在升级过程中,升级脚本报错,错误信息为:
ORA-01720:不存在'SYS.DUAL'的授权选项
而这些报错的视图都有一个特性,都使用了DUAL表
出问题后客户DBA第一时间介入排查但未找到解决方案导致客户只能回退版本,无法正常升级。在收到该问题反馈后,第一时间进行百度,但是实际上百度上的答案均无法解决客户的问题。
根据现场描述,在本地模拟最终分析出问题原因。根据用户反馈,程序共有两个用户分别是查询用户和更新用户,查询用户用于运维,更新用户则用于升级和程序的连接。因此为了演示用户的错误发生原因,需要使用PBB和PBB1两个用户来演示。其中PBB代表更新用户,PBB1代表查询用户。
首先为PBB和PBB1用户赋权,一般来说为了正常执行,用户必须要有
Connect 和resource两个角色的权限
grant connect to PBB;
grant resource to PBB;
grant connect to PBB1;
grant resource to PBB1;
由于涉及到视图,因此更新用户PBB1还需要create view的权限用于创建视图
grant create view to PBB;
然后查看报错脚本发现均是由 from dual的视图引起,因此创建模拟脚本并执行创建视图
create or replace view v_pbb as Select DUMMY from dual;
然后将V_PBB视图赋予给PBB1用户,在赋予权限前首先在生产上通过以下语句查询可以得知用户赋予了对象哪些权限
select * from dba_tab_privs where TABLE_NAME LIKE '%V_PBB%'
客户生产的赋权就像上图一样,所以我们需要用使用DBA或者更高权限的用户赋权,从这里其实就能看出客户存在过度赋权的情况。为了模拟过度赋权执行以下命令
grant all on pbb.V_PBB to pbb1;
最后执行升级脚本
create or replace view v_pbb as Select DUMMY from dual;
结果出错了,并且错误和反馈的一致。
这是为什么呢?
这就得从DUAL说起,首先DUAL是SYS用户下的一张表,我们平时select * from dual是通过公共同义词来访问的。为了查询同义词的底层表你必须拥有对表的查询权限,而这个权限已经包含在connect角色中了,所以一旦你被赋予了connect角色你也就拥有了对这张表的查询权限。有且仅有查询权限
当我们用DBA或者更高权限的用户将PBB的V_PBB视图赋予给PBB1时,因为客户使用了ALL,所以PBB1因此得到了V_PBB的所有操作权限。
但是当我们重新在PBB用户下替换这个视图的时候也就意味着在PBB刷新了给予PBB1的权限,但是这时候无法完成赋权,因为PBB想将DUAL的所有权限赋值给PBB1,但是PBB本身只有SELECT 权限,而不包含其他权限。所以导致视图的替换就无法完成。所以这时候就抛出ora-01720:不存在'SYS.DUAL'的授权选项的错误了
为了解决这个问题非常简单,只要移除视图V_PBB除SELECT以外的权限即可。或者删除V_PBB视图然后重新创建也可以,因为删除的时候所有赋权也会一并移除,当然之后千万别忘记重新赋予SELECT权限。
所以这个问题实际上是客户赋权引起的一个问题,而在正确的赋权情况下,from dual的视图是不应该赋予select以外权限的。
需要特别注意的是经过多个版本的测试发现11.2.0.4之前的版本可以通过错误的方式赋权(即上面的错误在11.2.0.4之前的版本是不会报错的),但是11.2.0.4以及之后的版本是不允许错误赋权的,客户的版本刚好是11.2.0.4
本人主要从事于数据库方面的性能优化,文章首发微信公众号,我会不定期在公众号分享数据库方面的知识(主要为Oracle),如果你对文章内容感兴趣,欢迎关注我的公众号:
唯一的小彬哥
WYDXBG2021
猜你喜欢
- 2025-07-28 JDK高版本特性总结与ZGC实践(jdk高版本兼容低版本吗)
- 2024-10-30 深入理解 volatile 关键字 volatile关键字的应用场景
- 2024-10-30 JVM知识点总览:高级Java工程师面试必备
- 2024-10-30 关于Eclipse 无法安装高版本Tomcat的解决办法
- 2024-10-30 面试官:连 INSERT INTO SET 都不知道怎么用,你这3年都干些什么了?
- 2024-10-30 Java 14 新功能介绍 java技术介绍
- 2024-10-30 MySQL 避坑指南之隐式数据类型转换
- 2024-10-30 Oracle,SQL Server 数据库较MySql数据库,Sql语句差异
- 2024-10-30 Oracle中PL/SQL基本语法 oracle的pl/sql
- 2024-10-30 Oracle数据库扩展语言PL/SQL之Procedure
你 发表评论:
欢迎- 636℃几个Oracle空值处理函数 oracle处理null值的函数
- 629℃Oracle分析函数之Lag和Lead()使用
- 617℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 613℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 611℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 603℃【数据统计分析】详解Oracle分组函数之CUBE
- 590℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 576℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)