- 1、本文档共7页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Oracle 12C用户创建与表空间分配
数据库安装完成后,首先用系统用户链接数据库容器(CDB),
在数据库容器(CDB)中创建表空间‘imei’
SQLcreate tablespace iemi datafileE:\Oracle_DB\ cdb_iemi.dbfsize 10240m autoextend on next 200m;
表空间已创建。
接下来在Oracle 12C数据库中创建用户报ORA-65096错误。
SQL create user 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 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。
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.
PDBS
CDB中可以有一个或多个PDBS,PDBS向后兼容,可以像以前在数据库中那样操作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: 表空间’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;
用户已创建。
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 404882167
文档评论(0)