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

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

遇到的坑

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

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

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

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

因为服务器重启时,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

oracle12c的CDB与PDB相关推荐

  1. oracle12c多个pdb,ProxmoxVE 之 oracle12C 多CDB和PDB

    上面左边是我的个人微信,如需进一步沟通,请加微信.  右边是我的公众号"Openstack私有云",如有兴趣,请关注. 继上次在PVE环境上搭建了oracle12C RAC环境(请 ...

  2. oracle12c racpdb,Oracle 12C R2的CDB与PDB简单管理操作

    Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库( ...

  3. oracle12c官方文档中文版_三分钟让你真正读懂oracle12c 中cdb pdb概念及原理

    Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库( ...

  4. oracle中pdb,Oracle 12C新特性-CDB和PDB 详解

    最近看到好多人都在尝试Oracle中的12C新特性-容器数据库,今年3月Orcle推出了Release2版本,可以算是一个稳定版本了.下午着手尝试了一下,还是蛮不错得 1.前言 CDB与PDB是Ora ...

  5. Oracle12cR2的CDB与PDB简单管理操作

    Oracle 12C引入了CDB与PDB的新特性,在ORACLE 12C数据库引入的多租用户环境(Multitenant Environment)中,允许一个数据库容器(CDB)承载多个可插拔数据库( ...

  6. Oracle 12C CDB、PDB常用管理命令

    --查看PDB信息(在CDB模式下) show pdbs --查看所有pdb select name,open_mode from v$pdbs; --v$pdbs为PDB信息视图 select co ...

  7. CDB和PDB的创建、连接、启动、关闭

    CDB和PDB的创建.连接.启动.关闭 一.CDB和PDB基本管理 基本概念: Multitenant Environment:多租户环境 CDB(Container Database):数据库容器 ...

  8. oracle pdb还原为no-cdb,oracle 12c中CDB和PDB的备份还原实验

    本文档分为两部分: 1.单个pdb备份还原 2.只cdb备份还原 1.rman只备份pdb SQL> show pdbs CON_ID CON_NAME                      ...

  9. oracle orclpdb是什么,oracle cdb、pdb参考

    oracle cdb.pdb参考 发布时间:2020-07-11 14:00:40 来源:51CTO 阅读:609 作者:春秋小记 CDB.PDB概念介绍 CDB与PDB是Oracle 12C引入的新 ...

  10. oracle的cbd和pdb区别,Oracle 12C CDB、PDB常用管理命令

    Oracle 12C CDB.PDB常用管理命令 --查看PDB信息(在CDB模式下) show pdbs --查看所有pdbselect name,open_mode from v$pdbs; -- ...

最新文章

  1. 成功跳槽百度工资从15K涨到28K,专题解析
  2. SQL Server 存储过程的应用
  3. iOS点击获取短信验证码按钮
  4. python 协程和异步的关系_python 协程和异步I/O的实践
  5. linux交叉编译jpeg,libjpeg的交叉编译以及jpeg图片的缩放(缩略图)
  6. 了解C ++中的Vector insert()
  7. C#信息采集系统,常见控件练习
  8. Android腾讯微博开放平台入门(一)开题与BaseString
  9. 计算机那个是固态硬盘,固态硬盘的好处是什么?电脑使用固态硬盘有什么用
  10. 人工智能AI 生成的艺术:从文本到图像
  11. 中国芝麻市场竞争规模及销售渠道分析报告2022-2028年版
  12. Android 3G/4G流量上网原理简析
  13. SEO 和 SEM 的优缺点有哪些区别和优势
  14. XP访问网络共享文件夹的方法
  15. Bokeh可视化笔记——x轴设为日期
  16. c语言程序代码有什么用,用c语言编写的代码程序是什么?
  17. linux redis 高级命令,Redis的高级应用之事务处理、持久化操作、pub_sub、虚拟内存...
  18. # MASA MAUI Plugin (十)iOS消息推送(原生APNS方式)
  19. Amdahl定律及木桶原理
  20. ffmpeg调整缩放裁剪视频的基础知识(转)

热门文章

  1. 内核木马:Win32.Rootkit.Rogue.Tzim查杀
  2. 台式计算机怎么开声音,台式机如何设置声音
  3. 云编程那些事2 - Java之父的啤酒密谋
  4. 6个UI面试技巧让你轻松入职大公司
  5. DirectX显示流程学习小结
  6. java中实现正态分布
  7. realme怎么互传_分享照片和视频 手机互传如何轻松搞定?
  8. 人机融合智能时代的人心
  9. 钓鱼指北 Gophish钓鱼平台和邮件服务器搭建
  10. 双引号在python中什么意思_Python中单引号和双引号的作用