1. 程式人生 > >oracle12c的CDB與PDB

oracle12c的CDB與PDB

oracle12c的新特性

Oracle 12C引入了CDB與PDB的新特性,在ORACLE 12C資料庫引入的多租使用者環境(Multitenant Environment)中,允許一個數據庫容器(CDB)承載多個可插拔資料庫(PDB)。CDB全稱為Container Database,中文翻譯為資料庫容器,PDB全稱為Pluggable Database,即可插拔資料庫。在ORACLE 12C之前,例項與資料庫是一對一或多對一關係(RAC):即一個例項只能與一個數據庫相關聯,資料庫可以被多個例項所載入。而例項與資料庫不可能是一對多的關係。當進入ORACLE 12C後,例項與資料庫可以是一對多的關係。下面是官方文件關於CDB與PDB的關係圖。關係圖

cdb相當於作業系統,呼叫並管理各個pdb。pdb相當於真正提供業務需求的資料庫例項。oracle 12c安裝後只建立了cdb,需要自己生成相應的pdb。oracle 12c使用了CDB-PDB架構,類似於docker,在container-db內可以載入多個pluggable-db.

 

理解了CDB與PDB的關係後我們就知道,我們的平時的資料庫操作大多數和PDB相關

oracle 12c截止2018年7月25日是兩個版本,一個是Oracle Database 12c 第 1 版,另一個是Oracle Database 12c 第 2 版

Oracle Database 12c 第 1 版安裝的時候會預設安裝一個名稱為pdborcl的例項(Oracle Database 12c 第 2 版預設名是orclpdb),具體安裝不再敘說,詳情請參閱:

https://blog.csdn.net/anxpp/article/details/51345074

安裝圖例

 

安裝成功後修改tnsnames.ora

我的在D:\app\oracle\product\12.1.0\dbhome_1\NETWORK\ADMIN資料夾下

############################tnsnames.ora######################

#cdb

orcl =

(DESCRIPTION =

 (ADDRESS_LIST =

 (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521)) )

 (CONNECT_DATA =

 (SERVICE_NAME = orcl) #cdb的db_name

 )

)

#pdb

pdborcl =

(DESCRIPTION =

 (ADDRESS_LIST =

 (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))

 )

 (CONNECT_DATA =

 (SERVICE_NAME = pdborcl) #pdb的db_name

 )

)

##########################tnsnames.ora######################

PLSQL Developer

資料庫下拉框會出現pdborcl選項

 

遇到的坑

 

使用system登入,PLSQL Developer選擇ORCL,執行

select name,open_mode from v$pdbs; 用來檢視當前CDB容器中包含的PDB容器

坑圖1

 pdborcl的open_mide的狀態是READ WRITE,使用pdborcl也能登入,但是你重啟伺服器這個狀態會變為

坑圖2

這時候PLSQL Developer選擇pdborcl就不能登入了,出現錯誤

坑圖3

 

因為伺服器重啟時,pdb預設不啟動

PLSQL Developer選擇ORCL. system登入(或使用sqlplus)執行

alter pluggable database PDBORCL open; 啟動pdb

建立使用者

建立新使用者,注意CDB容器中建立一個通用使用者,使用者名稱必須以C##或者c##開頭,因為CDB中預設建立的是common user

如果想要建立本地使用者,則要在PDB容器中建立,下面會說如何切換到PDB容器

create user C##test identified by 123456;    //其中C##test為使用者名稱,123456為密碼

 

給新使用者授權

grant create session to C##test;  
           grant create table to   C##test;  
           grant create tablespace to   C##test;  
           grant create view to   C##test;

 

切換至查到的某個PDB容器(上面查到的是PDBORCL)

注意使用這個命令需要的sysdba級別的許可權,否則無法執行,切換後才可使用當前pdb的私有使用者進行操作,12c資料庫建立完成後,預設情況下使用sqlplus / as sysdba  登入連線的是CDB。

 

alter session set container=PDBORCL

切換到PDB容器就可以建立本地使用者了

create user test identified by 123456;

如果要切換回CDB容器只需將容器名換為CDB容器的名字即可,一個CDB只有一個根

 alter session set container=CDB$ROOT;   

 

常用命令

切換當前會話到某個pdb中。

 

alter session set container=PDBNAME

 

關閉當前會話所在的cdb/pdb

 

startup/shutdown immediate

 

開啟指定pdb

 

alter pluggable database PDBNAME open ;

 

關閉指定pdb

alter pluggable database PDBNAME close immediate ;

 

啟動或者關閉一個或多個 PDB,指定的名稱為一個以逗號分隔的列表

 

啟動或者關閉 all pdbs
           ALTER PLUGGABLE DATABASE ALL OPEN;
           ALTER PLUGGABLE DATABASE ALL CLOSE IMMEDIATE;

 

可插接式資料庫(PDB) 自動啟動

預設情況下,在CDB 啟動的時候,all 的PDB 都是mount狀態。我們可以通過觸發器來實現pdbs隨cdb自動啟動,但這裡可以通過觸發器來實現PDB的自動open:

 

sqlplus / as sysdba
SQL> show con_name



CON_NAME
------------------------------
CDB$ROOT

 


SQL>
CREATE OR REPLACE TRIGGER open_pdbs
AFTER STARTUP ON DATABASE
BEGIN
EXECUTE IMMEDIATE 'ALTER PLUGGABLE DATABASE ALL OPEN';
END open_pdbs;
/

 

 

其他

--第1步:建立臨時表空間

create temporary tablespace TBS_JBDP_TEMP  

tempfile 'd:\oracle\product\oradata\TBS_JBDP_TEMP.dbf'

size 50m  

autoextend on  

next 50m maxsize 20480m  

extent management local;  

 

--第2步:建立資料表空間

create tablespace TBS_JBDP_DATA  

logging  

datafile 'd:\oracle\product\oradata\TBS_JBDP_DATA.dbf'

size 50m  

autoextend on  

next 50m maxsize 20480m  

extent management local;

 

 

--第3步:建立使用者並指定表空間

create user hjjc identified by hjjc123456  

default tablespace TBS_JBDP_DATA  

temporary tablespace TBS_JBDP_TEMP;  

 

--第4步:給使用者授予許可權

grant connect,resource,dba to hjjc;

 

--刪除使用者

drop user hjjc cascade;

 

--刪除表空間(含物理位置)

drop tablespace  TBS_JBDP_DATA  including contents and datafiles;

 

 

參考

https://blog.csdn.net/aaronmer/article/details/78748952

https://www.jb51.net/article/106497.htm

https://cloud.tencent.com/info/3b736c62a8acb13e8aff0fbcd91686fb.html