前言
由于oracle 12c使用了CDB-PDB架構(gòu),類似于docker,在container-db內(nèi)可以加載多個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的數(shù)據(jù)庫名,所有sid與oracle環(huán)境變量保持一致#
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”連接。如果出現(xiàn)ora-01017,很有可能是
二、創(chuàng)建pdb
cdb相當(dāng)于操作系統(tǒng),調(diào)用并管理各個pdb。pdb相當(dāng)于真正提供業(yè)務(wù)需求的數(shù)據(jù)庫實例。oracle 12c安裝后只創(chuàng)建了cdb,需要自己生成相應(yīng)的pdb。
1、創(chuàng)建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狀態(tài)為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 ; #調(diào)用dbms_pdb進(jìn)行pdb
3、新增用戶
create user scott account unlock identified by tiger ;
grant resource to scott ;
按照上述方法創(chuàng)建用戶,如果出現(xiàn)ora-01017,很有可能是1、沒有指定連接的service_name到具體pdb,或者oracle對密碼大小寫敏感。前者檢查listener.ora中sid_list是否已經(jīng)列出該pdb,并檢查連接字符串是否在tnsnames.ora指定。后者如果無法修改前端程序,可以使用
alter system set SEC_CASE_SENSITIVE_LOGON = false ;
強制關(guān)閉oracle的大小寫檢查進(jìn)行確認(rèn)。
三、常用命令
show pdbs:查看當(dāng)前數(shù)據(jù)庫container中包含有多少個pdb。如果session在某個pdb中,可以查看當(dāng)前的pdb。
alter session set container=PDBNAME
切換當(dāng)前會話到某個pdb中。切換后才可使用當(dāng)前pdb的私有用戶進(jìn)行操作
startup/shutdown immediate
關(guān)閉當(dāng)前會話所在的cdb/pdb
alter pluggable database PDBNAME open ;
打開指定pdb
alter pluggable database PDBNAME close immediate ;
關(guān)閉指定pdb
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
您可能感興趣的文章:- Oracle 用戶權(quán)限管理方法
- oracle用戶權(quán)限、角色管理詳解
- Oracle中sys和system用戶、系統(tǒng)權(quán)限和角色的區(qū)別
- Oracle刪除當(dāng)前用戶下所有表的方法適用于有或沒有刪除權(quán)限
- oracle用戶權(quán)限管理使用詳解
- MySQL與Oracle 差異比較之七用戶權(quán)限
- Oracle的用戶、角色及權(quán)限相關(guān)操作
- Oracle 創(chuàng)建用戶及數(shù)據(jù)表的方法
- oracle命令行刪除與創(chuàng)建用戶的代碼
- Oracle創(chuàng)建設(shè)置查詢權(quán)限用戶的方法