千家信息网

Oracle 12c及以上手工创建pdb

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,1、通过seed方式创建CREATE PLUGGABLE DATABASE salespdbADMIN USER salesadm IDENTIFIED BY passwordROLES = (dba
千家信息网最后更新 2025年01月19日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。


0