欢迎访问 生活随笔!

生活随笔

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

数据库

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

发布时间:2025/7/14 数据库 42 豆豆
生活随笔 收集整理的这篇文章主要介绍了 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)与用户详解的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。