码迷,mamicode.com
首页 > 数据库 > 详细

oracle 12c 创建PDB用户即Local User (PDB与CDB)

时间:2016-12-12 17:16:16      阅读:308      评论:0      收藏:0      [点我收藏+]

标签:xtend   环境   size   name   例子   角色   rac   空间   environ   

Oracle 12C用户创建与表空间分配 
数据库安装完成后,首先用系统用户链接数据库容器(CDB), 在数据库容器(CDB)中创建表空间‘imei’ SQL>create 
tablespace 
iemi 
datafile‘E:\Oracle_DB\ 
cdb_iemi.dbf‘size 10240m autoextend on next 200m; 表空间已创建。 
接下来在Oracle 12C数据库中创建用户时会报ORA-65096错误。 SQL> create user imei identified by imei default tablespace imei temporary tablespace imei_temp; * 
ERROR at line 1: 
ORA-65096: invalid common user or role name ORA-65096:公用用户名或角色名无效 
以前没见过这个错误,通用用户(common user)是什么?之前的版本可是没这概念啊,上网搜索看到了下面的图片,原来和common user对应的还有local user。

 

技术分享

 

这个common user 和local user是和oracle 12c的新特性pluggable database(PDB)有关。在PDB中创建的用户就是local user。从上图可以看出,common user必须以大写或小写的c##开头,尝试建立以c##开头的common user。 

SQL> create user c##imei identified by imei default tablespace imei temporary tablespace imei_temp;; User created. 
SQL> grant dba to c##imei; Grant succeeded. 
每个PDB都是独立的单元,有自己的用户(local user)、表空间、数据文件,每个local user只能访问自己的PDB,而common user只要权限足够,可以访问任意PDB。

 

Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为Container Database,中文翻译为数据库容器,PDB全称为Pluggable Database,即可插拔数据库。在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC):即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。而实例与数据库不可能是一对多的关系。当进入ORACLE 12C后,实例与数据库可以是一对多的关系。下面是官方文档关于CDB与PDB的关系图。 

技术分享

 

CDB组件(Components of a CDB) 一个CDB数据库容器包含了下面一些组件: ROOT组件 
ROOT又叫CDB$ROOT, 存储着ORACLE提供的元数据和Common User,元数据的一个例子是ORACLE提供的PL/SQL包的源代码,Common User 是指在每个容器中都存在的用户。

 

oracle 12c 创建PDB用户即Local User (PDB与CDB)

标签:xtend   环境   size   name   例子   角色   rac   空间   environ   

原文地址:http://www.cnblogs.com/zouhao/p/6165205.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!