admin 发表于 2018-11-10 21:51:32

Oracle12c创建新用户提示公共用户名或角色无效

 今天将备份的数据库还原到一台新的电脑上,首先要创建用户,执行如下语句:create user fxhyidentified by "123456"default tablespace USERStemporary tablespace TEMP;
  结果出现了一个错误:  https://images2015.cnblogs.com/blog/937319/201605/937319-20160528184434194-1811890575.png  我们可以看出提示的是:公共用户名或角色无效。这时候我就郁闷了,呃,查资料,发现创建用户的时候要以c##开头,也就是刚才的创建语句应该这么写:create user c##fxhyidentified by "123456"default tablespace USERStemporary tablespace TEMP;
  就这样试了一下,果真创建成功了,可是为什么要这么做,有些不明白,然后继续查资料,原因是这样的:  Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为Container Database,中文翻译为数据库容器,PDB全称为Pluggable Database,即可插拔数据库。在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC):即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。而实例与数据库不可能是一对多的关系。当进入ORACLE 12C后,实例与数据库可以是一对多的关系。下面是官方文档关于CDB与PDB的关系图。  https://images2015.cnblogs.com/blog/937319/201605/937319-20160528185500194-1192480634.png
  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;
    执行结果如下:   https://images2015.cnblogs.com/blog/937319/201605/937319-20160528190547741-1111652059.jpg  怎么查看CDB中的PDB信息?    执行下面这条语句:      select con_id, dbid, guid, name , open_mode from v$pdbs;

   执行结果如下:

   https://images2015.cnblogs.com/blog/937319/201605/937319-20160528190828647-1426910651.png
 启动PDB数据库的方式:
  
   执行下面这条语句:
 
     alter pluggable database PDBORCL open;

   执行结果如下:https://images2015.cnblogs.com/blog/937319/201607/937319-20160709134149483-1407730704.png
关闭PDB数据库的方式:
  
   执行下面这条语句:
 alter pluggable database PDBORCL close;

   执行结果如下:https://images2015.cnblogs.com/blog/937319/201607/937319-20160709140816342-401509006.png  在容器间切换:   alter session set container=PDBORCL;alter session set container=CDB$ROOT;
--------------------------------------------------------------分割线------------------------------------------------------------------------那么说了这么多,怎么就可以创建用户而不用加c##了呢,我在这里创建一个新的数据库,步骤如下:  打开 Database Configuration Assistant  https://images2015.cnblogs.com/blog/937319/201607/937319-20160709135930014-299866533.png  出现如下界面:https://images2015.cnblogs.com/blog/937319/201607/937319-20160709140105202-698574039.png  点击“下一步”出现如下界面,在创建数据库的时候将“创建为容器数据库”项取消勾选。https://images2015.cnblogs.com/blog/937319/201607/937319-20160709140208827-1285505437.png  这样新创建的数据库就可以使用了。

admin 发表于 2018-11-10 22:12:39

1  Container Database (CDB)

 

对于CDB,启动和关闭与之前传统的方式一样,具体语法如下:

STARTUP

SHUTDOWN

 

 

要注意,在12c数据库创建完成后,默认情况下使用sqlplus / as sysdba  登录连接的是CDB。

 

$ sqlplus / as sysdba

 

SQL*Plus:Release 12.1.0.1.0 Production on Thu Apr 24 17:50:34 2014

 

Copyright(c) 1982, 2013, Oracle.  All rightsreserved.

 

 

Connectedto:

OracleDatabase 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production

Withthe Partitioning, OLAP, Advanced Analytics and Real Application Testing options

 

SQL>show con_name

 

CON_NAME

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

CDB$ROOT

SQL>

 

SQL>select con_id, dbid, guid, name , open_mode from v$pdbs;

 

    CON_ID      DBID GUID                            NAME                          OPEN_MODE

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

         2 4088301206 F7C1E3C96BBF0585E0430A01A8C05459PDB$SEED                       READ ONLY

         3 426143573 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA                       READ WRITE

 

我们现在连接的是CDB,即root container。

 

我们关闭CDB:

SQL>shutdown immediate

Databaseclosed.

Databasedismounted.

ORACLEinstance shut down.

 

我们关闭CDB之前PDB 是没有关闭的,所以这个操作也会把PDB 关闭掉。

 

SQL>startup

ORACLEinstance started.

 

TotalSystem Global Area 1269366784 bytes

FixedSize                  2287912 bytes

VariableSize             788530904 bytes

DatabaseBuffers          469762048 bytes

RedoBuffers                8785920 bytes

Databasemounted.

Databaseopened.

 

SQL>  select con_id, dbid, guid, name , open_modefrom v$pdbs;

 

    CON_ID      DBID GUID                            NAME                          OPEN_MODE

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

         2 4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED                       READ ONLY

         3 426143573 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA                       MOUNTED

 

注意这里的PDB,在CDB 启动之,PDB 是自动启动到mount状态,而不是OPEN。 所以我们还需要手工去open它,当然,也可以通过在CDB中配置触发器来自动open。

 

 

2  Pluggable Database (PDB)

 

PDB 的操作可以通过SQL*PLUS 来操作,也可以通过ALTER PLUGGABLE DATABASE 命令操作。

 

2.1             使用SQL*Plus 命令

 

 

因为默认连接的是CDB,所以必须先指定PDB才可以通过sqlplus来启动和关闭PDB,

 

具体语法和普通实例一样:

 

STARTUPFORCE;

STARTUPOPEN READ WRITE ;

STARTUPOPEN READ ONLY ;

STARTUPUPGRADE;

SHUTDOWN;

 

SQL>show con_name

 

CON_NAME

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

CDB$ROOT

 

SQL>selectcon_id, dbid, guid, name , open_mode from v$pdbs;

 

    CON_ID      DBID GUID                            NAME            OPEN_MODE

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

         2 4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED       READ ONLY

         3 426143573 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA        MOUNTED

 

注意这里是mount,表示PDB 是关闭的。

 

--指定PDB 数据库:

SQL>alter session set container=pdbcndba;

Sessionaltered.

 

SQL>startup

PluggableDatabase opened.

SQL>select con_id, dbid, guid, name , open_mode from v$pdbs;

 

    CON_ID      DBID GUID                            NAME            OPEN_MODE

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

         3 426143573 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA        READ WRITE

SQL>

 

启动成功。 当我们切换到PDB之后,就看不到seed PDB的信息了。

 

 

2.2             使用ALTER PLUGGABLE DATABASE命令

 

如果在PDB中可以使用如下语法:

 

ALTERPLUGGABLE DATABASE OPEN READ WRITE ;

ALTERPLUGGABLE DATABASE OPEN READ ONLY ;

ALTERPLUGGABLE DATABASE OPEN UPGRADE ;

ALTERPLUGGABLE DATABASE CLOSE ;

 

如果是在CDB中,可以使用如下语法:

ALTERPLUGGABLE DATABASE <pdd-name-clause> OPEN READ WRITE ;

ALTERPLUGGABLE DATABASE <pdd-name-clause> OPEN READ ONLY ;

ALTERPLUGGABLE DATABASE <pdd-name-clause> OPEN UPGRADE ;

ALTERPLUGGABLE DATABASE <pdd-name-clause> CLOSE ;

 

<pdd-name-clause>表示的是多个PDB,如果有多个,用逗号分开。 也可以使用ALL或者ALL EXCEPT关键字来替代。

 

ALL:表示所有的PDBS。

ALLEXCEPT 表示需要排除的PDBS。

 

如:

ALTERPLUGGABLE DATABASE pdb1, pdb2 OPEN READ ONLY FORCE;

ALTERPLUGGABLE DATABASE pdb1, pdb2 CLOSE IMMEDIATE;

 

ALTERPLUGGABLE DATABASE ALL OPEN;

ALTERPLUGGABLE DATABASE ALL CLOSE IMMEDIATE;

 

ALTERPLUGGABLE DATABASE ALL EXCEPT pdb1 OPEN;

ALTERPLUGGABLE DATABASE ALL EXCEPT pdb1 CLOSE IMMEDIATE;

 

示例:

SQL>alter session set container=CDB$ROOT;

Sessionaltered.

 

SQL>select con_id, dbid, guid, name , open_mode from v$pdbs;

 

    CON_ID      DBID GUID                            NAME            OPEN_MODE

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

         2 4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED       READ ONLY

         3 426143573 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA        READ WRITE

 

SQL>ALTER PLUGGABLE DATABASE ALL CLOSE ;

Pluggabledatabase altered.

 

SQL>select con_id, dbid, guid, name , open_mode from v$pdbs;

 

    CON_ID      DBID GUID                            NAME            OPEN_MODE

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

         2 4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED       READ ONLY

         3  426143573 F7C209EB1DFC0854E0430A01A8C0B787PDBCNDBA        MOUNTED

 

SQL>alter session set container=pdbcndba;

 

Sessionaltered.

 

SQL>ALTER PLUGGABLE DATABASE OPEN;

 

Pluggabledatabase altered.

 

SQL>  select con_id, dbid, guid, name , open_modefrom v$pdbs;

 

    CON_ID      DBID GUID                            NAME            OPEN_MODE

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

         3  426143573 F7C209EB1DFC0854E0430A01A8C0B787PDBCNDBA        READ WRITE

 

 

 

3  设置Pluggable Database (PDB) 的自动startup

 

默认情况下,在CDB 启动的时候,all 的PDB 都是mount状态,也没有默认的机制,在CDB启动时自动启动PDB。

 

但这里可以通过触发器来实现PDB的自动open:

 

CREATEOR REPLACE TRIGGER open_pdbs

  AFTER STARTUP ON DATABASE

BEGIN

   EXECUTE IMMEDIATE 'ALTERPLUGGABLE DATABASE ALL OPEN';

END open_pdbs;

/

 

示例:

SQL>show con_name

 

CON_NAME

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

PDBCNDBA

SQL>alter session set container=CDB$ROOT;

 

Sessionaltered.

 

SQL>CREATE OR REPLACE TRIGGER open_pdbs

  2   AFTER STARTUP ON DATABASE

  3 BEGIN

  4    EXECUTE IMMEDIATE 'ALTER PLUGGABLE DATABASE ALL OPEN';

  5  ENDopen_pdbs;

  6  /

 

Triggercreated.

 
页: [1]
查看完整版本: Oracle12c创建新用户提示公共用户名或角色无效