oracle 12c創建可插拔數據庫(PDB)與用戶詳解


前言

由於oracle 12c使用了CDB-PDB架構,類似於docker,在container-db內可以加載多個pluggable-db,因此安裝后需要額外配置才能使用。

一、修改listener.ora , tnsnames.ora

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
###listener.ora###
LISTENER =
(DESCRIPTION =
  (ADDRESS = (PROTOCOL = TCP)(HOST = localhost)(PORT = 1521))
  (CONNECT_DATA = (SERVICE_NAME = orcl))
)
#sid list列舉cdb和所有pdb的數據庫名,所有sid與oracle環境變量保持一致#
SID_LIST_LISTENER =
(SID_LIST =
  (SID_DESC =
  (GLOBAL_DBNAME = orcl) #cdb db_name
  (SID_NAME = orcl)
  )
  (SID_DESC =
  (GLOBAL_DBNAME = pdborcl) #pdb db_name
  (SID_NAME = orcl)
  )
)
###listener.ora###
 
##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###

在客戶端連接時使用“service_name+domain_name”連接。如果出現ora-01017,很有可能是

二、創建pdb

cdb相當於操作系統,調用並管理各個pdb。pdb相當於真正提供業務需求的數據庫實例。oracle 12c安裝后只創建了cdb,需要自己生成相應的pdb。

1、創建pdb

在sqlplus下:

?
1
2
3
4
create pluggable database pdborcl
admin user pdbadmin identified by pdbadmin
role=(resource)
file_name_convert=( 'PDB$SEED's directory' , 'PDBOrcl's directory' );

2、同步文件

?
1
select pdb_name,status from cdb_pdbs

若pdb狀態為need sync,則需要:

?
1
alter sesseion set container=pdborcl

shutdown immediate或者alter pluggable database pdborcl close immediate ;

?
1
2
alter pluggable database pdborcl open restricted ;
exec dbms_pdb.sync_pdb ; #調用dbms_pdb進行pdb

3、新增用戶

?
1
2
create user scott account unlock identified by tiger ;
grant resource to scott ;

按照上述方法創建用戶,如果出現ora-01017,很有可能是1、沒有指定連接的service_name到具體pdb,或者oracle對密碼大小寫敏感。前者檢查listener.ora中sid_list是否已經列出該pdb,並檢查連接字符串是否在tnsnames.ora指定。后者如果無法修改前端程序,可以使用

?
1
alter system set SEC_CASE_SENSITIVE_LOGON = false ;

強制關閉oracle的大小寫檢查進行確認。

三、常用命令

show pdbs:查看當前數據庫container中包含有多少個pdb。如果session在某個pdb中,可以查看當前的pdb。

?
1
alter session set container=PDBNAME

切換當前會話到某個pdb中。切換后才可使用當前pdb的私有用戶進行操作

?
1
startup/shutdown immediate

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

?
1
alter pluggable database PDBNAME open ;

打開指定pdb

?
1
alter pluggable database PDBNAME close immediate ;

關閉指定pdb

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM