前言
由於oracle 12c使用了CDB-PDB架構,類似於docker,在container-db內可以加載多個pluggable-db,因此安裝後需要額外配置才能使用。
一、修改listener.ora , tnsnames.ora
###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下:
create pluggable database pdborcl admin user pdbadmin identified by pdbadmin role=(resource) file_name_convert=( 'PDB$SEED's directory' , 'PDBOrcl's directory' );
2、同步文件
select pdb_name,status from cdb_pdbs
若pdb狀態為need sync,則需要:
alter sesseion set container=pdborcl
shutdown immediate或者alter pluggable database pdborcl close immediate ;
alter pluggable database pdborcl open restricted ; exec dbms_pdb.sync_pdb ; #調用dbms_pdb進行pdb
3、新增用戶
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指定。後者如果無法修改前端程序,可以使用
alter system set SEC_CASE_SENSITIVE_LOGON = false ;
強制關閉oracle的大小寫檢查進行確認。
三、常用命令
show pdbs:查看當前數據庫container中包含有多少個pdb。如果session在某個pdb中,可以查看當前的pdb。
alter session set container=PDBNAME
切換當前會話到某個pdb中。切換後才可使用當前pdb的私有用戶進行操作
startup/shutdown immediate
關閉當前會話所在的cdb/pdb
alter pluggable database PDBNAME open ;
打開指定pdb
alter pluggable database PDBNAME close immediate ;
關閉指定pdb
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。