今天在oracle12c上建立用户,报错了。以下图:数据库
我很郁闷, 就打开了oracle官方网站找了下, 发现建立用户是有限制的。c#
2.解决方案session
建立用户的时候用户名以c##或者C##开头便可。oracle
错误写法: create user zhaojiedi identified by oracle; 正确写法: create user c##zhaojiedi identified by oracle;
注: 若是你不纠结为啥的,上面的解决方案就能够知足你的要求了,下面的内容能够不用看了。ide
========================================================================网站
========================================================================ui
3. 解决过程spa
下面的流程是我对于这个问题的解决过程, 也写出来分享分享。翻译
我进入oracle 12c官方文档的3d
依次进入如下页面
Managing Users and Securing the Database
Oracle Database Security Guide
通过一番查找,在Creating User Accounts 页面找到了以下图的内容:
上面提示的很明确了。 建立公共用户名必需要以c##或者C##开头了。咱们上面的报错了。 就是由于咱们建立公共用户没用以c##或者C##开头的。
到此咱们就知道具体错误的缘由了。 那就赢的解决方案就有了哈。
若是你还纠结公用用户和本地用户是啥东东的,Creating User Accounts 页面就有简介。
========================================================================
有些不明白,而后继续查资料,缘由是这样的:
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 是指在每一个容器中都存在的用户。
SEED组件:
Seed又叫PDB$SEED,这个是你建立PDBS数据库的模板,你不能在Seed中添加或修改一个对象。一个CDB中有且只能有一个Seed. 这个感念,我的感受很是相似SQL SERVER中的model数据库。
PDBS:
CDB中能够有一个或多个PDBS,PDBS向后兼容,能够像之前在数据库中那样操做PDBS,这里指大多数常规操做。
这些组件中的每个均可以被称为一个容器。所以,ROOT(根)是一个容器,Seed(种子)是一个容器,每一个PDB是一个容器。每一个容器在CDB中都有一个独一无二的的ID和名称。
怎么查看数据库是否为CDB?
执行下面这条语句:
select CDB from v$database;
若是获得的结果为YES,那么就是CDB的数据库,不然,则不是。
怎么查看当前的容器?
执行下面这条语句:
show con_name;
执行结果以下:
怎么查看CDB中的PDB信息?
执行下面这条语句:
select con_id, dbid, guid, name , open_mode from v$pdbs;
执行结果以下:
启动PDB数据库的方式:执行下面这条语句:
alter pluggable database PDBORCL open;
执行结果以下:
关闭PDB数据库的方式:执行下面这条语句:
alter pluggable database PDBORCL close;
执行下面这条语句:
在容器间切换:
alter session set container=PDBORCL; alter session set container=CDB$ROOT;
--------------------------------------------------------------分割线------------------------------------------------------------------------
那么说了这么多,怎么就能够建立用户而不用加c##了呢,我在这里建立一个新的数据库,步骤以下:
打开 Database Configuration Assistant
出现以下界面:
点击“下一步”出现以下界面,在建立数据库的时候将“建立为容器数据库”项取消勾选。
这样新建立的数据库就能够使用了。