ITPub博客

首页 > 数据库 > Oracle > 12C多租户关于CDB、PDB的常用SQL语句

12C多租户关于CDB、PDB的常用SQL语句

原创 Oracle 作者:lusklusklusk 时间:2020-02-23 12:19:19 0 删除 编辑

查看当前容器和当前用户

show con_name user

select sys_context('userenv', 'con_name'),sys_context('userenv','session_user') from dual;


查看所有PDB

show pdbs

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


启动PDB:

alter pluggable database all open; --开启所有PDB

alter pluggable database PDBNAME open; --开启名称为PDBNAME的PDB

alter session set container=PDBNAME;--切换名称为PDBNAME的PDB里面去开启

startup


关闭PDB:

alter pluggable database all close immediate; --关闭所有PDB,不加immediate就是默认的normal

alter pluggable database PDBNAME close immediate;--关闭名称为PDBNAME的PDB,不加immediate就是默认的normal

alter session set container=PDBNAME;--切换名称为PDBNAME的PDB里面去关闭

shutdown immediate


创建一个新的PDB:(已经存在db_create_file_dest的情况下)

create pluggable database test admin user admin identified by admin;   

alter pluggable database test open;    --将test打开


根据seed模板创建一个新PDB(不存在db_create_file_dest的情况下,必须加上file_name_convert)

create pluggable database pdb1 admin user pdb1 identified by pdb1 file_name_convert=('/u01/app/oracle/oradata/ocp/pdbseed','/u01/app/oracle/oradata/ocp1/pdb1');

alter pluggable database pdb1 open;    --将test打开


克隆PDB

create pluggable database test2 from test; --test必须是打开的,才可以作为克隆源

alter pluggable database test2 open;  --然后打开这个pdb


删除PDB

alter pluggable database test2 close immediate;  --关闭之后才能删除

drop pluggable database test2 including datafiles;  --删除PDB test2并同时把数据文件也从磁盘上删除了,必须加上including datafiles,不加including datafiles或加keep datafiles都会报错ORA-65179: cannot keep datafiles for a pluggable database that is not unplugged


unplug拔下某个数据库(必须要into到具体的xml格式的文件)

SQL> alter pluggable database pocp1 close immediate;--之后执行cdb_data_files查不到该pdb的数据文件,但是该pdb的数据文件还在, show pdbs还可以看到该pdb

SQL> alter pluggable database pocp1 unplug into '/home/oracle/pocp1.xml';--之后执行cdb_data_files查不到该pdb的数据文件,但是该pdb的数据文件还在, show pdbs还可以看到该pdb

SQL> drop pluggable database pocp1;  --unplug后drop database不加including datafiles就是默认的keep datafiles;该pdb的数据文件还在,show pdbs看不到该pdb;加了including datafiles的话,该pdb的数据文件被删除了

drop pluggable database pocp1=drop pluggable database pocp1 keep datafiles


插上这个数据库(上面的拔下操作执不执行第三步drop操作的话,执行如下语句会报错ORA-65012: Pluggable database pocp1 already exists,上面的拔下操作执第三步时加了including datafiles则执行如下语句会报错ORA-19505: failed to identify file,ORA-27037: unable to obtain file status)

SQL> create pluggable database pocp1 using '/home/oracle/pocp1.xml' nocopy tempfile reuse;

SQL> alter  pluggable database pocp1 open;


插上一个数据库时可以修改PDB名称,/home/oracle/pocp1.xml是pocp1创建的,该xml文件中显示<pdbname>POCP1</pdbname>,但是可以利用该xml创建一个其他名称的PDB,比如TDB101

SQL>create pluggable database TDB101 using '/home/oracle/pocp1.xml' nocopy tempfile reuse;


查询CDB$ROOT的数据文件

select file_name from cdb_data_files where con_id=1;


查询某个PDB的数据文件

select file_name from cdb_data_files a,cdb_pdbs b where a.con_id=b.con_id and b.pdb_name='XX'


查询某个数据文件对应的PDB

select pdb_name from cdb_data_files a,cdb_pdbs b where a.con_id=b.con_id and a.file_name like '%XX%';


查询PDB$SEED的数据文件

alter session set "_exclude_seed_cdb_view"=FALSE;

select file_name from cdb_data_files where con_id=2;


每个PDB执行如下语句只能看到自己这个容器下的数据文件,CDB才能看到所有容器的数据文件

select file_name,file_id,CON_ID from cdb_data_files;


每个容器执行如下语句只能看到自己这个容器下的数据文件,CDB也只能看到自己这个容器的数据文件

select file_name,file_id,CON_ID from cdb_data_files;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/30126024/viewspace-2676841/,如需转载,请注明出处,否则将追究法律责任。

请登录后发表评论 登录
全部评论
Welcome to Lukes DB HOME。 10G OCP、11G OCM, 8年以上DBA工作经验,博客仅记录自己的一个学习过程,不代表完全准确,如有需要,欢迎转载。

注册时间:2015-02-02

  • 博文量
    396
  • 访问量
    577654