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######################
數據庫下拉框會出現pdborcl選項
遇到的坑
使用system登錄,PLSQL Developer選擇ORCL,執行
select name,open_mode from v$pdbs; 用來查看當前CDB容器中包含的PDB容器
pdborcl的open_mide的狀態是READ WRITE,使用pdborcl也能登錄,但是你重啟服務器這個狀態會變為
這時候PLSQL Developer選擇pdborcl就不能登錄了,出現錯誤
因為服務器重啟時,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;