表空间

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

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

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

表空间的典型应用

  1. 控制用户所占用的表空间配额

    • 建立不同的表空间,为其设置最大的存储容量,然后把用户归属于这个表空间。如此的话,这个用户的存储容量,就受到这个表空间大小的限制。
  2. 控制数据库所占用的磁盘空间

  3. 灵活放置表空间,提高数据库的输入输出性能

    • 可以将不同类型的数据放置不同的表空间中,比如与湖南省相关的数据文件就放置在湖南省的这个表空间中。北京的就放在北京这个表空间中。
  4. 大表的排序操纵

    • 针对这种容量比较大的表对象,往往把它放在一个独立的表空间,以提高数据库性能。

默认表空间

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

  1. SYSTEM

    • 所有的dictionary object都存在SYSTEM表空间里面,存在SYS用户的表,视图,存储过程对象。
  2. SYSAUX

    • 作为SYSTEM表空间的辅助表空间,减轻SYSTEM表空间负荷。
  3. USERS

    • 存储用户创建的数据库对象
  4. UNDOTBS

    • 存储撤销信息的undo表空间。
  5. EXAMPLE

    • 数据库示例的表空间
  6. TEMP

    • 临时表空间主要用途是在数据库进行排序运算,管理索引,访问视图等操纵时提供的临时的运算空间,当运算完成之后系统会自动清理。

表空间查询命令

  1. 查询所有的表空间

    select * from V$tablespace
  2. 查看表空间的数据文件

    select file_name,tablespace_name from dba_data_files
  3. 查看用户的默认表空间

    select default_tablespace,temporary_tablespace from dba_users where username='用户名';
  4. 查看指定表空间有哪些表

    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 表空间和权限的更多相关文章

  1. Oracle 11g常用管理命令(用户、表空间、权限)

    PS:下面是Oracle 11g最常用的基本管理命令,包括创建用户.表空间,权限分配等.以下命令本人都验证操作过,并加上了本人的小结与说明. 1.启动oracle数据库: 从root切换到oracle ...

  2. Oracle表空间,用户,用户授权

    一:Oracle表空间 1,Oracle表空间与SQL Server文件组对比 SQL Server的文件组(文件组包括若干MDF,NDF数据文件)对我们来说并不陌生,前段时间我在博客“怎样玩转千万级 ...

  3. Oracle表空间管理

    oracle表空间相关常用命令小结: 1.ALTER DATABASE SET DEFAULT BIGFILE TABLESPACE;              //修改表空间数据文件类型 2.ALT ...

  4. 【转】Oracle 表空间与数据文件

    --============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或 ...

  5. interview:about Oracle表空间

    Oracle表空间 SQL Server数据库与Oracle数据库之间最大的区别要属表空间设计.Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献.可 ...

  6. Oracle 表空间扩充

    Oracle 表空间扩充 一.现场环境: (1)操作系统:AIX (2)数据库:Oracle Database 10g Enterprise Edition Release 10.2.0.5.0 - ...

  7. Oracle 表空间与数据文件

    -============================== --Oracle 表空间与数据文件 --============================== /* 一.概念 表空间:是一个或多 ...

  8. oracle 表空间总结

                           表空间总结  一.认识表空间 1:表空间概念: 表空间是数据库中最大的逻辑单位,Oracle数据库采用表空间将相关的逻辑组件组合在一起,一个Oracle数 ...

  9. Oracle 表空间查询与操作方法

    一.查询篇 1.查询oracle表空间的使用情况 select b.file_id 文件ID,  b.tablespace_name 表空间,  b.file_name 物理文件名,  b.bytes ...

随机推荐

  1. 【vue】获取异步加载后的数据

    异步请求的数据,对它做一些处理,需要怎么做呢?? axios 异步请求数据,得到返回的数据, 赋值给变量 info .如果要对 info 的数据做一些处理后再赋值给 hobby ,直接在 axios ...

  2. mysql安装教程,mysql安装配置教程

    MySQL的安装教程 一.MYSQL的安装 首先登入官网下载mysql的安装包,官网地址:https://dev.mysql.com/downloads/mysql/ 一般下载这个就好,现在的最新版本 ...

  3. DL4J实战之一:准备

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  4. 使用vxe table组件时,edit-render配置$select',选中option后关闭cell的激活状态,显示选中option的value问题

    在我的项目中使用vxe table组件时,edit-render配置{name: '$select', options: [{label:"脉搏",value:"maib ...

  5. Spring IOC Container原理解析

    Spring Framework 之 IOC IOC.DI基础概念 关于IOC和DI大家都不陌生,我们直接上martin fowler的原文,里面已经有DI的例子和spring的使用示例 <In ...

  6. Arcscene教程

    ​ ​ ​ ​ ​ ​ ​ ​ ​ ​​ ​ 筛选​ ​ ​ ​ ​ ​ ​ ​ 看不清的话可以进行如下操作:右键-->属性-->符号系统-->把高程前面的对号取消-->添加- ...

  7. 洛谷4895 独钓寒江雪 (树哈希+dp+组合)

    qwq 首先,如果是没有要求本质不同的话,那么还是比较简单的一个树形dp 我们令\(dp[i][0/1]\)表示是否\(i\)的子树,是否选\(i\)这个点的方案数. 一个比较显然的想法. \(dp[ ...

  8. python中冒泡排序代码实现

    1.冒泡排序代码如下图: #冒泡算法l=[12,4,56,10,6,2]for i in range(0,6): for j in range(i+1,6): if l[i]>l[j]: a=l ...

  9. HttpServletRequest 入门

    1. request对象和response对象的原理 request和response对象是由服务器创建的.我们来使用它们 request对象是来获取请求消息,response对象是来设置响应消息 2 ...

  10. JavaScript中的模式匹配

    JavaScript中的模式匹配 模式是用于转换输入数据的规则. 以将数据与一个或多个逻辑结构进行比较,将数据分解为各个构成部分,或以各种方式从数据中提取信息. 安装 JavaScript已经实现模式 ...