Oracle表空间与权限的深入讲解


Posted in Oracle onNovember 17, 2021

表空间

表空间是数据库的逻辑划分,一个表空间只能属于一个数据库。所有的数据库对象都存放在指定的表空间中。但主要存放的是表,所以称作表空间。

Oracle中很多优化都是基于表空间的设计理念而实现的,一个数据库可以包含多个表空间,一个表空间只能属于一个数据库。一个表空间包含多个数据文件,一个数据文件只能属于一个表空间。

Oracle 数据库中至于存放一个表空间,即SYSTEM的表空间。

表空间的典型应用

  1. 控制用户所占用的表空间配额
    1. 建立不同的表空间,为其设置最大的存储容量,然后把用户归属于这个表空间。如此的话,这个用户的存储容量,就受到这个表空间大小的限制。
  2. 控制数据库所占用的磁盘空间
  3. 灵活放置表空间,提高数据库的输入输出性能。
    1. 可以将不同类型的数据放置不同的表空间中,比如与湖南省相关的数据文件就放置在湖南省的这个表空间中。北京的就放在北京这个表空间中。
  4. 大表的排序操纵
    1. 针对这种容量比较大的表对象,往往把它放在一个独立的表空间,以提高数据库性能。

默认表空间

系统中默认创建的几个表空间

  1. SYSTEM
    1. 所有的dictionary object都存在SYSTEM表空间里面,存在SYS用户的表,视图,存储过程对象。
  2. SYSAUX
    1. 作为SYSTEM表空间的辅助表空间,减轻SYSTEM表空间负荷。
  3. USERS
    1. 存储用户创建的数据库对象
  4. UNDOTBS
    1. 存储撤销信息的undo表空间。
  5. EXAMPLE
    1. 数据库示例的表空间
  6. TEMP
    1. 临时表空间主要用途是在数据库进行排序运算,管理索引,访问视图等操纵时提供的临时的运算空间,当运算完成之后系统会自动清理。

表空间查询命令

查询所有的表空间

select * from V$tablespace

查看表空间的数据文件

select file_name,tablespace_name from dba_data_files

查看用户的默认表空间

select default_tablespace,temporary_tablespace from dba_users where username='用户名';

查看指定表空间有哪些表

select table_name,tablespace_name from dba_tables where tablespace_name='表空间名称'

创建表空间

create tablespace test_data datafile 'test_data.dbf' size 32M autoextend on next 32M maxsize 2048M extent management local

创建临时表空间

create temporary tablespcae test_temp tempfile 'test_temp.dbf' size 32M autoextend on next 32M maxsize 2048M extent management local

删除表空间

drop tablespace 表空间名 including contents and datafiles

给用户赋予表空间

create user 用户名 identified by 密码 default tablespace 默认表空间 temporary  tablespace 临时表空间

用户与表空间的关系

一个用户可以使用一个或者多个表空间,一个表空间也可以供多个用户使用。

用户和表空间没有隶属关系,表空间是一个用来管理存储数据的逻辑概念,表空间只是和数据文件发生关系,数据文件是物理的,一个表空间可以包含多个数据文件,而一个数据文件只能隶属一个表空间。

查看用户默认表空间

select username,deafult_tablespace from dba_users where username='用户名'

查看当前用户拥有的表

select table_name from user_tables

权限分类

1、系统权限

系统规定用户使用数据库的权限。(系统权限是对用户而言)。系统权限只能由DBA用户授出

最开始就是这两个用户(sys,system)

2、对象权限

某种权限用户对其他用户的表或者视图存取权限。(是针对表或视图而言)

系统权限

允许用户执行特定的数据库动作,如创建表、创建索引、连接实例等。

  1. dba角色: 拥有全部特权,是系统最高权限。
  2. resource角色:拥有resource权限的用户只可以访问数据库对象。
  3. connect角色:拥有connect权限的用户只可以登录Oracle,不可以访问数据库对象

注意:以上都是角色,不算单个权限,算是一群权限的集合。

查看所有系统权限

SELECT * FROM SYSTEM_PRIVILEGE_MAP

系统权限

允许用户操纵一些特定的对象,如读取视图,可更新某些列、执行存储过程等

select, update, insert, alter, index, delete, all …… //all包括所有权限

execute //执行存储过程权限

给用户授权

系统权限

grant 系统权限 to 用户名 [WITH ADMIN OPTION]
grant connect, resource to 用户名;

对象权限

grant 对象权限 on 对象 to 用户  [WITH GRANT OPTION]
grant select, update, insert on product to 用户名;
grant all on product to 用户名;  // all 表示全部对象权限
grant all on product to 用户名;  // public表示是所有的用户

撤销用户权限

撤销系统权限

revoke 系统权限 from 用户;
revoke resource from 用户名;

撤销对象权限

revoke 对象权限 on 对象 from 用户
revoke select, update on product from 用户

角色

角色就是一组权限(privilege),更加方便对权限进行管理,每种角色都用于执行一些特定的管理任务。

  • 创建角色/删除角色
create role 角色名 / drop role 角色名
  • 给角色授权

系统权限: grant 系统权限 to 角色

对象权限: grant 对象权限 on 对象 to 角色

  • 撤消角色权限

revoke 系统权限 from 角色

revoke 对象权限 on 对象 from 角色

查看权限

查看当前用户所有系统权限

select * from user_sys_privs

查看当前用户所属角色

select * from user_role_privs

角色有哪些系统权限

select * from role_sys_privs

角色有哪些对象权限(sys用户下)

select * from role_tab_privs

用户有哪些对象权限

select * from user_tab_privs

总结

到此这篇关于Oracle表空间与权限的文章就介绍到这了,更多相关Oracle表空间与权限内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Oracle 相关文章推荐
ORACLE数据库对long类型字段进行模糊匹配的解决思路
Apr 07 Oracle
oracle表分区的概念及操作
Apr 24 Oracle
Oracle创建只读账号的详细步骤
Jun 07 Oracle
SQL模糊查询报:ORA-00909:参数个数无效问题的解决
Jun 21 Oracle
RPM包方式安装Oracle21c的方法详解
Aug 23 Oracle
Oracle安装TNS_ADMIN环境变量设置参考
Nov 01 Oracle
使用Oracle命令进行数据库备份与还原
Dec 06 Oracle
Oracle数据库中通用的函数实例详解
Mar 25 Oracle
Oracle中DBLink的详细介绍
Apr 29 Oracle
Oracle 11g数据库使用expdp每周进行数据备份并上传到备份服务器
Jun 28 Oracle
oracle delete误删除表数据后如何恢复
Jun 28 Oracle
详解Oracle块修改跟踪功能
Nov 07 #Oracle
Oracle安装TNS_ADMIN环境变量设置参考
Nov 01 #Oracle
关于Oracle12C默认用户名system密码不正确的解决方案
Oct 16 #Oracle
C#连接ORACLE出现乱码问题的解决方法
Oct 05 #Oracle
Oracle 临时表空间SQL语句的实现
Sep 25 #Oracle
oracle索引总结
Sep 25 #Oracle
Oracle 死锁的检测查询及处理
Sep 25 #Oracle
You might like
用PHP动态生成虚拟现实VRML网页
2006/10/09 PHP
clientX,pageX,offsetX,x,layerX,screenX,offsetLeft区别分析
2010/03/12 Javascript
JavaSript中变量的作用域闭包的深入理解
2014/05/12 Javascript
深入理解JavaScript系列(26):设计模式之构造函数模式详解
2015/03/03 Javascript
详解jQuery移动页面开发中的ui-grid网格布局使用
2015/12/03 Javascript
JS实现鼠标滑过显示边框的菜单效果
2016/09/21 Javascript
解析Javascript单例模式概念与实例
2016/12/05 Javascript
用jQuery实现优酷首页轮播图
2017/01/09 Javascript
详解Vue-Cli 异步加载数据的一些注意点
2017/08/12 Javascript
全选复选框JavaScript编写小结(附代码)
2017/08/16 Javascript
Angularjs过滤器实现动态搜索与排序功能示例
2017/12/13 Javascript
nodejs前端模板引擎swig入门详解
2018/05/15 NodeJs
vue通信方式EventBus的实现代码详解
2019/06/10 Javascript
ES6扩展运算符和rest运算符用法实例分析
2020/05/23 Javascript
vue 解决兄弟组件、跨组件深层次的通信操作
2020/07/27 Javascript
解决ant Design中Select设置initialValue时的大坑
2020/10/29 Javascript
详解ES6 扩展运算符的使用与注意事项
2020/11/12 Javascript
微信小程序实现购物车功能
2020/11/18 Javascript
linux环境下的python安装过程图解(含setuptools)
2017/11/22 Python
详谈python3 numpy-loadtxt的编码问题
2018/04/29 Python
使用pandas 将DataFrame转化成dict
2019/12/10 Python
keras tensorflow 实现在python下多进程运行
2020/02/06 Python
keras 获取某层的输入/输出 tensor 尺寸操作
2020/06/10 Python
CSS3等相关属性制作分页导航实现代码
2012/12/24 HTML / CSS
Sandro Paris美国官网:典雅别致的法国时尚服饰品牌
2017/12/26 全球购物
Crocs波兰官方商店:女鞋、男鞋、童鞋、洞洞鞋
2019/10/08 全球购物
英国在线照明超市:Castlegate Lights
2019/10/30 全球购物
意大利奢侈品综合电商网站:MODES
2019/12/14 全球购物
深入开展党的群众路线教育实践活动方案
2014/02/04 职场文书
关于对大人不礼貌的检讨书
2014/09/29 职场文书
出国留学导师推荐信
2015/03/26 职场文书
跟班学习心得体会(共6篇)
2016/01/23 职场文书
《绝招》教学反思
2016/02/20 职场文书
《攀登者》:“海拔8000米以上,你不能指望任何人”
2019/11/25 职场文书
Redis数据结构之链表与字典的使用
2021/05/11 Redis
分布式锁为什么要选择Zookeeper而不是Redis?看完这篇你就明白了
2021/05/21 Redis