日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

oracle 12c创建可插拔数据库(PDB)与用户详解

發布時間:2025/7/14 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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

總結

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

轉載于:https://www.cnblogs.com/jxldjsn/p/8175634.html

總結

以上是生活随笔為你收集整理的oracle 12c创建可插拔数据库(PDB)与用户详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。