oracle12c的CDB与PDB

oracle12c的新特性

Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB)。CDB全称为Container Database,中文翻译为数据库容器,PDB全称为Pluggable Database,即可插拔数据库。在ORACLE 12C之前,实例与数据库是一对一或多对一关系(RAC):即一个实例只能与一个数据库相关联,数据库可以被多个实例所加载。而实例与数据库不可能是一对多的关系。当进入ORACLE 12C后,实例与数据库可以是一对多的关系。下面是官方文档关于CDB与PDB的关系图。关系图

cdb相当于操作系统,调用并管理各个pdb。pdb相当于真正提供业务需求的数据库实例。oracle 12c安装后只创建了cdb,需要自己生成相应的pdb。oracle 12c使用了CDB-PDB架构,类似于docker,在container-db内可以加载多个pluggable-db.

 

理解了CDB与PDB的关系后我们就知道,我们的平时的数据库操作大多数和PDB相关

oracle 12c截止2018年7月25日是两个版本,一个是Oracle Database 12c 第 1 版,另一个是Oracle Database 12c 第 2 版

Oracle Database 12c 第 1 版安装的时候会默认安装一个名称为pdborcl的实例(Oracle Database 12c 第 2 版默认名是orclpdb),具体安装不再叙说,详情请参阅:

https://blog.csdn.net/anxpp/article/details/51345074

安装图例

 

安装成功后修改tnsnames.ora

我的在D:\app\oracle\product\12.1.0\dbhome_1\NETWORK\ADMIN文件夹下

############################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######################

PLSQL Developer

数据库下拉框会出现pdborcl选项

 

遇到的坑

 

使用system登录,PLSQL Developer选择ORCL,执行

select name,open_mode from v$pdbs; 用来查看当前CDB容器中包含的PDB容器

坑图1

 pdborcl的open_mide的状态是READ WRITE,使用pdborcl也能登录,但是你重启服务器这个状态会变为

坑图2

这时候PLSQL Developer选择pdborcl就不能登录了,出现错误

坑图3

 

因为服务器重启时,pdb默认不启动

PLSQL Developer选择ORCL. system登录(或使用sqlplus)执行

alter pluggable database PDBORCL open; 启动pdb

创建用户

创建新用户,注意CDB容器中创建一个通用用户,用户名必须以C##或者c##开头,因为CDB中默认创建的是common user

如果想要创建本地用户,则要在PDB容器中创建,下面会说如何切换到PDB容器

create user C##test identified by 123456;    //其中C##test为用户名,123456为密码

 

给新用户授权

grant create session to C##test;  
           grant create table to   C##test;  
           grant create tablespace to   C##test;  
           grant create view to   C##test;

 

切换至查到的某个PDB容器(上面查到的是PDBORCL)

注意使用这个命令需要的sysdba级别的权限,否则无法执行,切换后才可使用当前pdb的私有用户进行操作,12c数据库创建完成后,默认情况下使用sqlplus / as sysdba  登录连接的是CDB。

 

alter session set container=PDBORCL

切换到PDB容器就可以创建本地用户了

create user test identified by 123456;

如果要切换回CDB容器只需将容器名换为CDB容器的名字即可,一个CDB只有一个根

 alter session set container=CDB$ROOT;   

 

常用命令

切换当前会话到某个pdb中。

 

alter session set container=PDBNAME

 

关闭当前会话所在的cdb/pdb

 

startup/shutdown immediate

 

打开指定pdb

 

alter pluggable database PDBNAME open ;

 

关闭指定pdb

alter pluggable database PDBNAME close immediate ;

 

启动或者关闭一个或多个 PDB,指定的名称为一个以逗号分隔的列表

 

启动或者关闭 all pdbs
           ALTER PLUGGABLE DATABASE ALL OPEN;
           ALTER PLUGGABLE DATABASE ALL CLOSE IMMEDIATE;

 

可插接式数据库(PDB) 自动启动

默认情况下,在CDB 启动的时候,all 的PDB 都是mount状态。我们可以通过触发器来实现pdbs随cdb自动启动,但这里可以通过触发器来实现PDB的自动open:

 

sqlplus / as sysdba
SQL> show con_name



CON_NAME
------------------------------
CDB$ROOT

 


SQL>
CREATE OR REPLACE TRIGGER open_pdbs
AFTER STARTUP ON DATABASE
BEGIN
EXECUTE IMMEDIATE 'ALTER PLUGGABLE DATABASE ALL OPEN';
END open_pdbs;
/

 

 

其他

--第1步:创建临时表空间

create temporary tablespace TBS_JBDP_TEMP  

tempfile 'd:\oracle\product\oradata\TBS_JBDP_TEMP.dbf'

size 50m  

autoextend on  

next 50m maxsize 20480m  

extent management local;  

 

--第2步:创建数据表空间

create tablespace TBS_JBDP_DATA  

logging  

datafile 'd:\oracle\product\oradata\TBS_JBDP_DATA.dbf'

size 50m  

autoextend on  

next 50m maxsize 20480m  

extent management local;

 

 

--第3步:创建用户并指定表空间

create user hjjc identified by hjjc123456  

default tablespace TBS_JBDP_DATA  

temporary tablespace TBS_JBDP_TEMP;  

 

--第4步:给用户授予权限

grant connect,resource,dba to hjjc;

 

--删除用户

drop user hjjc cascade;

 

--删除表空间(含物理位置)

drop tablespace  TBS_JBDP_DATA  including contents and datafiles;

 

 

参考

https://blog.csdn.net/aaronmer/article/details/78748952

https://www.jb51.net/article/106497.htm

https://cloud.tencent.com/info/3b736c62a8acb13e8aff0fbcd91686fb.html

 

 

 

 

转载:https://blog.csdn.net/qq877507054/article/details/81209967

 

 

 

 

本文作者:Journey&Flower

本文链接:https://www.cnblogs.com/JourneyOfFlower/p/13862674.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   Journey&Flower  阅读(343)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 404 Not Found REOL
  2. 2 白色恋人 游鸿明
  3. 3 盛夏的果实 莫文蔚
  4. 4 以父之名 周杰伦
  5. 5 晴天 周杰伦
  6. 6 简单爱 周杰伦
  7. 7 东风破 周杰伦
  8. 8 稻香 周杰伦
  9. 9 爱在西元前 周杰伦
  10. 10 千里之外 费玉清-周杰伦
  11. 11 偏爱 张芸京
  12. 12 大海 张雨生
  13. 13 月亮惹的祸 张宇
  14. 14 雨一直下 张宇
  15. 15 过火 张信哲
  16. 16 隐形的翅膀 张韶涵
  17. 17 天下 张杰
  18. 18 当你孤单你会想起谁 张栋梁
  19. 19 清明雨上 许嵩
  20. 20 玫瑰花的葬礼 许嵩
  21. 21 断桥残雪 许嵩
  22. 22 城府 许嵩
  23. 23 等一分钟 徐誉滕
  24. 24 客官不可以 徐良_小凌
  25. 25 坏女孩 徐良_小凌
  26. 26 犯贱 徐良
  27. 27 菠萝菠萝蜜 谢娜
  28. 28 贝多芬的悲伤 萧风
  29. 29 睫毛弯弯 王心凌
  30. 30 我不是黄蓉 王蓉
  31. 31 秋天不回来 王强
  32. 32 今天你要嫁给我 陶喆,蔡依林
  33. 33 丁香花 唐磊
  34. 34 绿光 孙燕姿
  35. 35 求佛 誓言
  36. 36 十一年 邱永传
  37. 37 下辈子如果我还记得你 马郁
  38. 38 一千年以后 林俊杰
  39. 39 江南 林俊杰
  40. 40 曹操 林俊杰
  41. 41 背对背拥抱 林俊杰
  42. 42 会呼吸的痛 梁静茹
  43. 43 勇气 梁静茹
  44. 44 爱你不是两三天 梁静茹
  45. 45 红日 李克勤
  46. 46 星月神话 金莎
  47. 47 嘻唰唰 花儿乐队
  48. 48 穷开心 花儿乐队
  49. 49 六月的雨-《仙剑奇侠传》电视剧插曲 胡歌
  50. 50 一个人的寂寞两个人的错 贺一航
  51. 51 好想好想-《情深深雨濛濛》电视剧片尾曲 古巨基
  52. 52 情人 刀郎
  53. 53 冲动的惩罚 刀郎
  54. 54 西海情歌 刀郎
  55. 55 2002年的第一场雪 刀郎
  56. 56 红玫瑰 陈奕迅
  57. 57 浮夸 陈奕迅
  58. 58 爱情转移 陈奕迅
  59. 59 独家记忆 陈小春
  60. 60 记事本 陈慧琳
  61. 61 看我72变 蔡依林
  62. 62 寂寞在唱歌 阿桑
  63. 63 樱花草 Sweety
  64. 64 中国话 S.H.E
  65. 65 波斯猫 S.H.E
  66. 66 杀破狼-《仙剑奇侠传》电视剧片头曲 JS
  67. 67 Lydia F.I.R.
  68. 68 I Miss You 罗百吉_青春美少女.
白色恋人 - 游鸿明
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 林利南

作曲 : 游鸿明

编曲 : 涂惠源

冷空气 却清晰

你在南极冰山雪地里

极光中雪白的肌肤

是哀愁是美丽

为了要遇见你

我连呼吸都反复练习

兰伯特仁慈的冰川

带领我走向你

零下九十一度的酷寒

滚滚红尘千年的呼喊

藏在沃斯托克的湖岸

沉寂轻叹

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮

零下九十一度的酷寒

滚滚红尘千年的呼喊

藏在沃斯托克的湖岸

沉静轻叹

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮

撒哈拉漫天狂沙 金字塔谁能解答

兵马俑谁与争锋 长城万里相逢

人世间悲欢聚散 一页页写在心上

含着泪白色恋人 却有灰色的年轮