oracle12c用户创建与表空间分配

上传人:第*** 文档编号:30579939 上传时间:2018-01-30 格式:DOC 页数:7 大小:78.50KB
返回 下载 相关 举报
oracle12c用户创建与表空间分配_第1页
第1页 / 共7页
oracle12c用户创建与表空间分配_第2页
第2页 / 共7页
oracle12c用户创建与表空间分配_第3页
第3页 / 共7页
oracle12c用户创建与表空间分配_第4页
第4页 / 共7页
oracle12c用户创建与表空间分配_第5页
第5页 / 共7页
点击查看更多>>
资源描述

《oracle12c用户创建与表空间分配》由会员分享,可在线阅读,更多相关《oracle12c用户创建与表空间分配(7页珍藏版)》请在金锄头文库上搜索。

1、Oracle 12C 用户创建与表空间分配数据库安装完成后,首先用系统用户链接数据库容器(CDB),在数据库容器(CDB)中创建表空间imeiSQLcreate tablespace iemi datafileE:Oracle_DB cdb_iemi.dbfsize 10240m autoextend on next 200m;表空间已创建。接下来在 Oracle 12C 数据库中创建用户时会报 ORA-65096 错误。SQL create user imei identified by imei default tablespace imei temporary tablespace im

2、ei_temp;*ERROR at line 1:ORA-65096: invalid common user or role nameORA-65096:公用用户名或角色名无效以前没见过这个错误,通用用户(common user)是什么?之前的版本可是没这概念啊,上网搜索看到了下面的图片,原来和 common user 对应的还有 local user。这个 common user 和 local user 是和 oracle 12c 的新特性pluggable database(PDB)有关。在 PDB 中创建的用户就是 local user。从上图可以看出,common user 必须以

3、大写或小写的 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 引入了

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

5、B 与 PDB 的关系图。CDB 组件(Components of a CDB)一个 CDB 数据库容器包含了下面一些组件:ROOT 组件ROOT 又叫 CDB$ROOT, 存储着 ORACLE 提供的元数据和 Common User,元数据的一个例子是 ORACLE 提供的 PL/SQL 包的源代码,Common User 是指在每个容器中都存在的用户。SEED 组件Seed 又叫 PDB$SEED,这个是你创建 PDBS 数据库的模板,你不能在 Seed 中添加或修改一个对象。一个 CDB 中有且只能有一个Seed. PDBSCDB 中可以有一个或多个 PDBS,PDBS 向后兼容,可以像

6、以前在数据库中那样操作 PDBS,这里指大多数常规操作。这些组件中的每一个都可以被称为一个容器。因此,ROOT(根)是一个容器,Seed(种子)是一个容器,每个 PDB 是一个容器。每个容器在 CDB 中都有一个独一无二的的 ID 和名称。用户名改好了,我们再次执行创建用户的语句SQL create user imei identified by imei default tablespace imei temporary tablespace imei_temp;*第一行出现错误:ORA-65048: 在可插入数据库 PDBORCL 中处理当前 DDL 语句时出错ORA-00959: 表空间

7、imei不存在再上网查询,得知 CDB 容器数据库创建新用户并分配表空间时必须在没有 PDB 的情况下进行或 PDB 与 CDB 有相同表空间的时候进行,否则会报错。如果是在 PDB 与 CDB 有相同表空间的情况下给 CDB 用户分配表空间,则会分配 CDB 的表空间给用户 PDB 的表空间并不受影响。首先看第一种情况,是在没有 PDB 的情况下创建用户“C#imei”并分配表空间(系统自带的表空间)。SQL create user imei identified by imei default tablespace SYSTEM temporary tablespace TEMP;用户已创

8、建。SQLgrant dba to c#imei;授权成功。下来看第二种:先用系统用户链接数据库容器(CDB),切换到 PDB。SQL select con_id,dbid,NAME,OPEN_MODE from v$pdbs;CON_ID DBID NAME OPEN_MODE- - - - 2 4048821679 PDB$SEED READ ONLY3 3313918585 PDBORCL MOUNTEDSQL alter PLUGGABLE database PDBORCL open;Pluggable database 已启动.SQL alter session set contai

9、ner=PDBORCL;会话已更改。SQL show con_name;CON_NAME-PDBORCLSQLcreate tablespace iemi datafileE:Oracle_DB pdb_iemi.dbfsize 10240m autoextend on next 200m;表空间已创建。再次用系统用户链接数据库容器(CDB),执行创建用户语句create user c#imei2 identified by imei default tablespace imei temporary tablespace imei_temp;用户已创建。SQLgrant dba to c#imei2;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 外语文库 > 英语学习

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号