一、oracle数据库的权限系统分为系统权限与对象权限:

  • 系统权限( database system privilege )可以让用户执行特定的命令集。例如,create table权限允许用户创建表,grant any privilege 权限允许用户授予任何系统权限。
  • 对象权限( database object privilege )可以让用户能够对各个对象进行某些操作。例如delete权限允许用户删除表或视图的行,select权限允许用户通过select从表、视图、序列(sequences)或快照(snapshots)中查询信息。

二、用户与角色权限:

  • 每个oracle用户都有一个名字和口令,并拥有一些由其创建的表、视图和其他资源。
  • oracle角色(role)就是一组权限(privilege)(或者是每个用户根据其状态和条件所需的访问类型)。
  • 用户可以给角色授予或赋予指定的权限,然后将角色赋给相应的用户。
  • 一个用户也可以直接给其他用户授权。

三、创建用户:

  oracle内部有两个建好的用户:system和sys。用户可直接登录到system用户以创建其他用户,因为system具有创建别 的用户的 权限。 在安装oracle时,用户或系统管理员首先可以为自己建立一个用户。
语法[创建用户]: create user 用户名 identified by 口令[即密码];
例子: create user test identified by test;
语法[更改用户]: alter user 用户名 identified by 口令[改变的口令];
例子: alter user test identified by ;

四、删除用户:

语法:drop user 用户名;
例子:drop user test;

若用户拥有对象,则不能直接删除,否则将返回一个错误值。指定关键字cascade,可删除用户所有的对象,然后再删除用户。

语法: drop user 用户名 cascade;
例子: drop user test cascade;

五、授权角色:

oracle为兼容以前版本,提供三种标准角色(role):connect、resource和dba。

1.讲解三种标准角色:

  • connect role(连接角色):临时用户,特指不需要建表的用户,通常只赋予他们connect role。connect是使用oracle简单权限,这种权限只对其他用户的表有访问权限,包括select/insert/update和delete等,还能够创建表、视图、序列(sequence)、簇(cluster)、同义词(synonym)、回话(session)和其他  数据的链(link)。
  • resource role(资源角色):更可靠和正式的数据库用户可以授予resource role。resource提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器(trigger)、索引(index)和簇(cluster)。
  • dba role(数据库管理员角色):拥有所有的系统权限。包括无限制的空间限额和给其他用户授予各种权限的能力。system由dba用户拥有

2.授权命令:

语法: grant connect, resource to 用户名;
例子: grant connect, resource to test;

3.撤销权限:

语法: revoke connect, resource from 用户名;
例子: revoke connect, resource from test;

六、创建/授权/删除角色:

  除了前面讲到的三种系统角色----connect、resource和dba,用户还可以在oracle创建自己的role。用户创建的role可以由表或系统权限或两者的组合构成。为了创建role,用户必须具有create role系统权限。

1.创建角色:

语法: create role 角色名;
例子: create role testRole;

2.授权角色:

语法: grant select on class to 角色名;
例子: grant select on class to testRole;

注:现在,拥有testRole角色的所有用户都具有对class表的select查询权限

3.删除角色

语法: drop role 角色名;
例子: drop role testRole;

注:与testRole角色相关的权限将从数据库全部删除

七、使用例子:

  • 使用dump导入数据:

步骤如下:

1.创建临时表空间:

create temporary tablespace TABLESPACE_TEMP tempfile 'D:/TABLESPACE_TEMP.DBF' size 100M reuse autoextend on next 20M maxsize unlimited;

2.创建表空间:

create tablespace TABLESPACE datafile 'D:/TABLESPACE.DBF' size 300M reuse autoextend on next 40M maxsize unlimited default storage(initial 128k next 128k minextents  maxextents unlimited);

3.创建用户到表空间上:

create user test identified by test## default tablespace TABLESPACE temporary tablespace TABLESPACE_TEMP;

4.为用户分配权限:

grant connect,resource to test;

5.使用dmp将数据库导入导出:

1)将数据库数据导出为dmp文件:

  • 将数据库orcl用户名test密码test#123#的数据导出到e:\test.dmp中:
exp test/test## file=e:\test.dmp full=y ignore=y
  • 将数据库user1与user2用户的表导出到d:\daochu.dmp中:
exp test/test##@orcl file=d:\daochu.dmp owner=(user1,user2)
  • 将数据库表T_USER、T_ROLE导出到d:\daochu.dmp中:
exp test/test##@orcl file=d:\daochu.dmp tables=(T_USER,T_ROLE) 
exp test/test#123#@xe file=/u01/app/oracle/T_USER.dmp tables=T_USER

2)将dmp文件数据导入到数据库中:

imp test/test## file=E:/test.dmp full=y ignore=y

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------

  • 创建普通用户,赋予简单的权限:

步骤如下:

## 创建一个用户

create user test identified by test##;

## 赋予create session的权限,此时用户可以登录数据库

grant create session to test;

## 赋予用户可以查看NANA下USER_LOG表权限

grant select on NANA.USER_LOG to test;

## 切换到NANA用户下执行
grant select on USER_LOG to test;

## 赋予用户创建表的权限,此时用户还没有使用表空间的权限

grant create table to test;

## 赋予用户使用表空间的权限,此时用户可以管理自己创建的表(增删改查)

grant unlimited tablespace to test;

## 查看用户拥有什么权限可以通过查询一个系统的视图(数字字典)

select * from user_sys_privs;

## 撤销权限

revoke create table from test; 

oracle数据库之用户管理的更多相关文章

  1. Oracle 数据库基本操作——用户管理与文件管理

    目录: 1.初始状态 2.登录数据库 3.创建表空间 1)概念 2) 基本表空间 3)表空间管理 4.创建新用户 5.删除用户 6.用户的授权 1)定义 2)授予权限的方法 3)权限分类 4)授权注意 ...

  2. oracle数据库一些用户管理语句

    查询所有数据库用户 select * from dba_users 查看数据库名称 select name from v$database 查看权限 select * from user_sys_pr ...

  3. Oracle DB 执行用户管理的备份和恢复

    • 说明用户管理的备份和恢复与服务器管理的备份和恢复 之间的差异 • 执行用户管理的数据库完全恢复 • 执行用户管理的数据库不完全恢复 备份和恢复的使用类型 数据库备份和恢复的类型包括: • 用户管理 ...

  4. oracle 数据库创建用户并授权

    oracle 数据库创建用户并授权 备注: userName 为用户名,123456 为密码 drop user userName cascade; create user userName iden ...

  5. Oracle基础和用户管理

    1.数据库的使用: 项目的规模:负载量(用户)有多大? 成本: 安全性:   (小型数据库)access.forbase 负载小 :100人以内,比如留言板,信息管理系统. 成本:千元以内. 安全性要 ...

  6. oracle 学习笔记--用户管理

    oracle 用户管理 创建用户(需要具有dba权限的用户) create user 用户名 identified by 密码 defaule tablespace users     //默认表空间 ...

  7. [Oracle]Oracle数据库任何用户密码都能以sysdba角色登入

    * 本文相关环境:Windows 10,64位操作系统:Oracle 11gR2:toad for Oracle12.1 最近在学习Oracle数据库,使用Toad for Oracle来查看数据库的 ...

  8. oracle工具 sqlplus 用户管理

    可以通过system用户对普通用户解锁.alter user scott account unlock; 工具:1/ sqlplusw sqlplus 自带.调用oracle安装目录下bin目录下的e ...

  9. Oracle数据库web维护管理及监控

    1.Oracle数据库客户端的种类及现状         目前Oracle数据库维护管理,通常是使用客户端软件:PL/SQL Developer,SQL* Plus,toad,em等进行数据的管理.维 ...

随机推荐

  1. Redis 的 Lua 脚本支持

    Redis 2.6.0 内置的Lua Script支持,可以在Redis的Server端一次运行大量逻辑. 整个Script默认是在一个事务里的. Script里涉及的所有Key尽量用变量,从外面传入 ...

  2. Ubuntu16.04下安装MATLAB 2016b!完美运行

    目录 1.下载MATLAB 2016b 2.挂载iso 3.安装MATLAB 4.破解 5.快捷键与运行 1.下载MATLAB 2016b 下载matlab 2016b for linux(可以百度搜 ...

  3. python保存字典和读取字典pickle

    import pickle import numpy as np def save_obj(obj, name): with open(name + '.pkl', 'wb') as f: pickl ...

  4. textarea的maxlength属性兼容解决方案

    IE10版本的textarea才支持maxlength属性:低版本的IE都不兼容,实际上低版本的IE的市场存在率还是很高的: 所以还是很有必要来整合一套解决方案的: Jquery版本 $(functi ...

  5. BZOJ1014 [JSOI2008]火星人

    Description 火星人最近研究了一种操作:求一个字串两个后缀的公共前缀.比方说,有这样一个字符串:madamimadam, 我们将这个字符串的各个字符予以标号:序号: 1 2 3 4 5 6 ...

  6. 关于MyEclipse2017Ci10版本的破解和Tomcat9.0的安装搭配使用

    昨天和今天就忙这两件事情了.废话不多说直接上干货! 首先是关于Myeclipse2017的破解,关于这个破解,网上的资源和文件很多,可以自行下载,我就不贴链接了. 我要说的是破解的问题,在这里我们要注 ...

  7. Canvas学习:globalCompositeOperation详解

    在默认情况之下,如果在Canvas之中将某个物体(源)绘制在另一个物体(目标)之上,那么浏览器就会简单地把源特体的图像叠放在目标物体图像上面. 简单点讲,在Canvas中,把图像源和目标图像,通过Ca ...

  8. react生命周期es6

    基本函数有 import React from 'react' export default class MyClass extends React.Component { constructor(p ...

  9. C语言——二叉排序树

    二叉排序树是一种实现动态查找的树表,又称二叉查找树. 二叉排序树的性质: 1. 若它的左子树不为空,则左子树上所有节点的键值均小于它的根节点键值 2. 若它的右子树不为空,则右子树上所有节点的键值均大 ...

  10. LaTeX 使用:itemize,enumerate,description 用法

    itemize和enumerate还有description 是LaTeX里列举的三种样式,分别讲一些使用技巧.itemize(意为分条目): \begin{itemize} \item[*] a \ ...