Oracle 12c及以上手工创建pdb
1、通过seed方式创建
CREATE PLUGGABLE DATABASE salespdb
ADMIN USER salesadm IDENTIFIED BY password
ROLES = (dba)
DEFAULT TABLESPACE sales
DATAFILE '/home/oracle/scripts/ORCL/salespdb/sales01.dbf' SIZE 250M AUTOEXTEND ON
FILE_NAME_CONVERT = ('/home/oracle/scripts/ORCL/pdbseed/','/home/oracle/scripts/ORCL/salespdb/')
STORAGE (MAXSIZE 2G)
PATH_PREFIX = '/home/oracle/scripts/ORCL/salespdb/'
说明:/disk1/oracle/dbs/pdbseed/为种子数据库数据文件存放路径,/disk1/oracle/dbs/salespdb/为新的pdb数据库文件存放路径。
2、通过已有的pdb创建(pdb必须处于打开模式)
ORA-65036: 插接式数据库 SALESPDB 未在所需模式下打开
CREATE PLUGGABLE DATABASE salespdb1 FROM salespdb
FILE_NAME_CONVERT = ('/home/oracle/scripts/ORCL/salespdb/', '/home/oracle/scripts/ORCL/salespdb1/')
PATH_PREFIX = '/home/oracle/scripts/ORCL/salespdb1';
3、手工创建pdb后错误(RESTRICTED值属于yes)
SQL> show pdbs;
CON_ID CON_NAME OPEN MODE RESTRICTED
---------- ------------------------------ ---------- ----------
2 PDB$SEED READ ONLY NO
3 PDB READ WRITE NO
4 SALESPDB READ WRITE YES
5 HQ_PDB READ WRITE YES
6 SALESPDB1 READ WRITE NO
select * from PDB_PLUG_IN_VIOLATIONS
原因
用种子PDB或插入或克隆方法创建PDB后,可以通过查询 CDB_PDBS 视图的STATUS 列查看新 PDB 的状态。
如果在打开新 PDB 之前创建了公用用户和角色,必须同步 PDB 才能从根检索新的公用用户和角色。
当 PDB 在读/写模式下打开时,会自动执行同步。如果在只读模式下打开 PDB,则会返回错误。
可以通过查询 PDB_PLUG_IN_VIOLATIONS 视图查看违规说明。
3. 方案
因此,唯一能做的就是在 PDBPROD2 中创建该表空间,关闭数据库,再次进行同步即可。
create tablespace sqlaudit_mon datafile '/home/oracle/scripts/ORCL/salespdb/sqlaudit_mon.dbf' size 10m;
create tablespace sqlaudit_mon datafile '/home/oracle/scripts/ORCL/salespdb1/sqlaudit_mon.dbf' size 10m;
在CDB下查询受限的PDB:
select con_id, name,open_mode,restricted from v$pdbs;
在PDB中查询相关受限的PDB:
select instance_name,logins,status from gv$instance (v$containers也可以查询)
cdb下更换 pdb restricted 模式:
alter pluggable database pdb_name close immediate instance=all;(all except pdb1)
alter pluggable database pdb_name open read write instance=all;
pdb下更换 pdb restricted 模式:
alter session set container=pdb_name;
alter session set container=SALESPDB;
alter pluggable database close immediate;
alter pluggable database open;
在受限模式下,可以授予特定用户 restricted session权限用于临时登录,记得revoke。