我的编程空间,编程开发者的网络收藏夹
学习永远不晚

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

作者:赵全文 网名:guest

    前日上午,开发同学反馈,应用程序在连接一套Oracle 11.2.0.4.0数据库的生产用户时,一直报“无操作表空间”的权限。于是,我赶紧连到SQLPLUS里进行查看该用户具有什么样的权限(包括系统权限、角色权限和对象权限),没有发现什么异常。大家都知道,一般在建立用户以后,都会给CONNECT和RESOURCE的角色权限。然后,我连到其它无报错的另一套Oracle 11.2.0.4.0数据库的生产用户上查看,两套数据库进行对比,发现报错的那套数据库没有“UNLIMITED TABLESPACE”的系统权限,给授予了该系统权限以后,又和开发同学联系,他说已经正常了。

    鉴于以上的故障处理,下面我们来看一看,Oracle数据库里的几个角色和用户是否具有UNLIMITED TABLESPACE的系统权限?

1.查看3个角色,CONNECT、RESOURCE和DBA。

(1)查看CONNECT角色,见下图,发现这个角色只具有CREATE SESSION的系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE


(2)查看RESOURCE角色,见下图,发现这个角色具有8个系统权限,但是没有发现UNLIMITED TABLESPACE的系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(3)查看DBA角色,见下图,发现该角色具有的系统权限更多,我对PRIVILEGE的列进行了降序处理,以U开头的系统权限都显示在了最前面,但并没有发现UNLIMITED TABLESPACE。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

2.查看2个用户,SYS和SYSTEM。

(1)查看SYS用户,见下图,发现SYS用户是具有UNLIMITED TABLESPACE的系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(2)查看SYSTEM用户,见下图,发现SYSTEM用户也具有UNLIMITED TABLESPACE的系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

从上面的查看,我们可以得出如下结论,

  • 角色CONNECT、RESOURCE和DBA都不具有UNLIMITED TABLESPACE的系统权限;

  • 用户SYS和SYSTEM都具有UNLIMITED TABLESPACE的系统权限。

接下来,我们再看看,3个角色CONNECT、RESOURCE和DBA具有什么样的角色权限?

1.角色CONNECT和RESOURCE,见下图,发现没有任何的角色权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

2.角色DBA,见下图,发现该角色具有很多的角色权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

最后,我们在测试库创建一个表空间TEST和一个用户TEST,并设置表空间TEST为用户TEST的默认表空间,授予CONNECT和RESOURCE的角色权限,观察该用户具有什么样的系统权限?操作步骤如下,

(1)查看数据库版本,如下图,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(2)创建表空间TEST,见下图,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(3)创建用户TEST,见下图,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(4)给用户TEST授予CONNECT的角色权限,并查看该用户具有的系统权限,见下图,发现并没有什么系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(5)给用户TEST授予RESOURCE的角色权限,并查看该用户具有的系统权限,见下图,居然发现具有了UNLIMITED TABLESPACE的系统权限。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

从这个操作和前面的演示可以得出,RESOURCE角色本身没有UNLIMITED TABLESPACE的系统权限,但是给普通用户授予了该角色,就使得该用户默认具有了UNLIMITED TABLESPACE的系统权限。带着这个疑问,查了一下Google,发现AskTom这个网站的回答很权威,而且很有说服力。见操作步骤,如下图,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

如上,有人提问Tom Kyte大师,为什么RESOURCE角色本身没有UNLIMITED TABLESPACE的系统权限,但是给普通用户授予了RESOURCE的角色,该用户就具有了UNLIMITED TABLESPACE的系统权限呢?

大师是这样回答的,那个UNLIMITED TABLESPACE的系统权限已经被硬编码到RESOURCE角色中了,是特殊的一个权限。见下图所示,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

下面还有来自印度的Haroon大师给出了评论,他是这样阐述的,在RESOURCE角色里,UNLIMITED TABLESPACE是一个隐藏的系统权限,它在Oracle 12.1.0.1的版本中已经修复了这个bug,并且在12.1.0.1中,创建的普通用户在授予RESOURCE的角色以后,默认不具有UNLIMITED TABLESPACE的系统权限,所以在撤销UNLIMITED TABLESPACE的权限时会报错,提示没有授予过该权限,见下图红色方框描述,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

下面把Tom Kyte大师的工作经历show一下,以作为我继续研究Oracle的源动力和精神支柱。

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

(6)给用户TEST授予DBA的角色权限,查看用户具有的系统权限,再将用户的DBA角色权限撤销,再次查看用户具有的系统权限有哪些?见下图操作,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

从上面两图可以得出,DBA的角色权限杀伤力很大呀,授予的时候,没什么影响,撤销的时候,就把原先的UNLIMITED TABLESPACE的系统权限悄悄的给收回了,感觉好恐怖哟!所以告诫大家,一定不要给普通用户授予DBA的角色权限,如果曾经授予过,再撤销以后,一定要给普通用户单独授予UNLIMITED TABLESPACE的系统权限或重新授予一次RESOURCE的角色权限。见下图所示,

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE




如果您觉得此篇文章对您有帮助,欢迎关注微信公众号:guestart的DBA学习笔记,您的支持是对我最大的鼓励!

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

谈谈Oracle 数据库的系统权限UNLIMITED TABLESPACE

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

浅谈python对象数据的读写权限

面向对象的编程语言在写大型程序的的时候,往往比面向过程的语言用起来更方便,安全。其中原因之一在于:类机制。 类,对众多的数据进行分类,封装,让一个数据对象成为一个完整的个体,贴近现实生活,高度抽象化。但是,python对类的封装并不好,因为
2022-06-04

Oracle DBA权限不足引发的数据库安全风险

Oracle DBA权限不足引发的数据库安全风险随着互联网的快速发展,数据库作为企业重要的信息存储和管理工具,承载着大量的敏感数据。在这个过程中,数据库管理员(DBA)起着至关重要的作用,负责保证数据库的正常运行以及数据的安全性。然而,由
Oracle DBA权限不足引发的数据库安全风险
2024-03-08

Oracle DBA权限不足引发的数据库安全风险

Oracle DBA权限不足引发的数据库安全风险随着互联网的快速发展,数据库作为企业重要的信息存储和管理工具,承载着大量的敏感数据。在这个过程中,数据库管理员(DBA)起着至关重要的作用,负责保证数据库的正常运行以及数据的安全性。然而,由
Oracle DBA权限不足引发的数据库安全风险
2024-03-08

Oracle变量与数据库角色和权限管理的结合

Oracle变量可以与数据库角色和权限管理结合使用,以实现更加灵活和安全的数据库管理。一种常见的做法是,创建一个包含所有需要的数据库角色和权限的角色,然后将这个角色赋予特定的Oracle变量。这样,当用户使用这个变量登录数据库时,就会自动
Oracle变量与数据库角色和权限管理的结合
2024-08-24

Oracle变量与数据库资源限制的关系

Oracle变量和数据库资源限制之间存在着一定的关系。在Oracle数据库中,系统管理员可以通过设置数据库资源限制来控制数据库用户对资源的使用。这些资源包括CPU、内存、I/O等。在这种情况下,Oracle变量的使用可能受到这些资源限制的影
Oracle变量与数据库资源限制的关系
2024-08-24

Oracle如何获取数据库系统的当前时间

目录oracle获取数据库系统的当前时间更新当前时间查询当前时间Oracle数据库 获取当前年月份总结Oracle获取数据库系统的当前时间mysql 中我们可以通过 NOW() 函数来获取系统的当前时间。但在 Oracle 中并没有 N
2022-12-12

Oracle和DB2数据库管理系统的特点对比

Oracle和DB2是两种常见的关系型数据库管理系统,它们都有各自独特的特点和优势。本文将对Oracle和DB2进行特点对比,并提供具体的代码示例来说明它们之间的差异。一、Oracle数据库管理系统的特点:存储引擎:Oracle数据库使用
Oracle和DB2数据库管理系统的特点对比
2024-03-11

Sybase与Oracle数据库管理系统的核心差异

Sybase与Oracle数据库管理系统的核心差异,需要具体代码示例数据库管理系统在现代信息技术领域中扮演着至关重要的角色,Sybase和Oracle作为两大知名的关系型数据库管理系统,在数据库领域中占据着重要地位。虽然它们都属于关系型数
Sybase与Oracle数据库管理系统的核心差异
2024-03-08

Sybase和Oracle数据库系统的功能与性能比较

Sybase和Oracle数据库系统的功能与性能比较随着信息技术的不断发展与进步,数据库系统作为企业管理信息化的基础设施之一,扮演着至关重要的角色。Sybase和Oracle作为主流的关系型数据库管理系统(RDBMS)之一,在各自的领域内
Sybase和Oracle数据库系统的功能与性能比较
2024-03-08

Oracle与Sybase数据库管理系统的比较与对比

Oracle与Sybase数据库管理系统的比较与对比随着信息技术的迅速发展,数据库管理系统的选择变得越来越重要。在众多数据库管理系统中,Oracle和Sybase是两个备受关注的产品。它们都拥有强大的功能和广泛的应用领域,但各自也有自己的
Oracle与Sybase数据库管理系统的比较与对比
2024-03-07

Oracle数据库中修改系统日期的操作指南

Oracle数据库是一种功能强大的关系型数据库管理系统,它具有许多用于管理数据库的功能和命令。其中,修改系统日期是一个常见但又比较特殊的操作,需要谨慎处理。本文将为您提供在Oracle数据库中修改系统日期的操作指南,并附上具体的代码示例。
Oracle数据库中修改系统日期的操作指南
2024-03-09

Oracle变量与数据库统计信息更新的关系

Oracle变量和数据库统计信息更新之间没有直接的关系。Oracle变量是用于存储数据的命名变量,可以在PL/SQL代码中使用。而数据库统计信息则是关于数据库对象(表、索引等)数据分布和存储结构的信息,用于优化查询性能。虽然Oracle变
Oracle变量与数据库统计信息更新的关系
2024-08-23

编程热搜

目录