在Oracle 12c中,分CDB 和PDB,他们的启动和关闭操作整理如下。

1 Container Database (CDB)

对于CDB,启动和关闭与之前传统的方式一样,具体语法如下:

STARTUP[NOMOUNT | MOUNT | RESTRICT | UPGRADE | FORCE | READ ONLY]

SHUTDOWN[IMMEDIATE | ABORT]

要注意,在12c数据库创建完成后,默认情况下使用sqlplus / as sysdba 登录连接的是CDB。

?
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
[oracle@Ora12c~]$
sqlplus / as sysdba
 
SQL*Plus:Release
12.1.0.1.0

Production on Thu Apr
24

17
:50:34

2014
 
Copyright(c)
1982,
2013,
Oracle. All rightsreserved.
 
Connectedto:
 
OracleDatabase
12c Enterprise Edition Release
12.1.0.1.0

- 64bit Production
 
Withthe
Partitioning, OLAP, Advanced Analytics and Real Application Testing options
 
SQL>show
con_name
 
CON_NAME
 
------------------------------
 
CDB$ROOT
 
SQL>
 
SQL>select
con_id, dbid, guid, name , open_mode from v$pdbs;
 
CON_ID
DBID GUID NAME OPEN_MODE
 
----------
------------------------------------------ ------------------------------ ----------
 
2

4088301206

F7C1E3C96BBF0585E0430A01A8C05459PDB$SEED READ ONLY
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA READ WRITE

我们现在连接的是CDB,即root container。

我们关闭CDB:

?
1
2
3
4
5
6
7
SQL>shutdown
immediate
 
Databaseclosed.
 
Databasedismounted.
 
ORACLEinstance
shut down.

我们关闭CDB之前PDB 是没有关闭的,所以这个操作也会把PDB 关闭掉。

?
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
SQL>startup
 
ORACLEinstance
started.
 
 
 
TotalSystem
Global Area
1269366784

bytes
 
FixedSize
2287912

bytes
 
VariableSize
788530904

bytes
 
DatabaseBuffers
469762048

bytes
 
RedoBuffers
8785920

bytes
 
Databasemounted.
 
Databaseopened.
 
 
 
SQL>
select con_id, dbid, guid, name , open_modefrom v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
----------
------------------------------------------ ------------------------------ ----------
 
2

4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED READ ONLY
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA MOUNTED

注意这里的PDB,在CDB 启动之,PDB 是自动启动到mount状态,而不是OPEN。 所以我们还需要手工去open它,当然,也可以通过在CDB中配置触发器来自动open。

2 Pluggable Database (PDB)

PDB 的操作可以通过SQL*PLUS 来操作,也可以通过ALTER PLUGGABLE DATABASE 命令操作。

2.1 使用SQL*Plus 命令

因为默认连接的是CDB,所以必须先指定PDB才可以通过sqlplus来启动和关闭PDB,

具体语法和普通实例一样:

?
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
STARTUPFORCE;
 
STARTUPOPEN
READ WRITE [RESTRICT];
 
STARTUPOPEN
READ ONLY [RESTRICT];
 
STARTUPUPGRADE;
 
SHUTDOWN[IMMEDIATE];
 
 
 
SQL>show
con_name
 
 
 
CON_NAME
 
------------------------------
 
CDB$ROOT
 
 
 
SQL>selectcon_id,
dbid, guid, name , open_mode from v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
--------------------
-------------------------------- --------------- ----------
 
2

4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED READ ONLY
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA MOUNTED
 
 
 
注意这里是mount,表示PDB
是关闭的。
 
 
 
--指定PDB
数据库:
 
SQL>alter
session set container=pdbcndba;
 
Sessionaltered.
 
 
 
SQL>startup
 
PluggableDatabase
opened.
 
SQL>select
con_id, dbid, guid, name , open_mode from v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
--------------------
-------------------------------- --------------- ----------
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA READ WRITE
 
SQL>

启动成功。 当我们切换到PDB之后,就看不到seed PDB的信息了。

2.2 使用ALTER PLUGGABLE DATABASE命令

如果在PDB中可以使用如下语法:

?
1
2
3
4
5
6
7
ALTERPLUGGABLE
DATABASE OPEN READ WRITE [RESTRICTED] [FORCE];
 
ALTERPLUGGABLE
DATABASE OPEN READ ONLY [RESTRICTED] [FORCE];
 
ALTERPLUGGABLE
DATABASE OPEN UPGRADE [RESTRICTED];
 
ALTERPLUGGABLE
DATABASE CLOSE [IMMEDIATE];

如果是在CDB中,可以使用如下语法:

?
1
2
3
4
5
6
7
ALTERPLUGGABLE
DATABASE <pdd-name-clause> OPEN READ WRITE [RESTRICTED][FORCE];
 
ALTERPLUGGABLE
DATABASE <pdd-name-clause> OPEN READ ONLY [RESTRICTED] [FORCE];
 
ALTERPLUGGABLE
DATABASE <pdd-name-clause> OPEN UPGRADE [RESTRICTED];
 
ALTERPLUGGABLE
DATABASE <pdd-name-clause> CLOSE [IMMEDIATE];

<pdd-name-clause>表示的是多个PDB,如果有多个,用逗号分开。 也可以使用ALL或者ALL EXCEPT关键字来替代。

ALL:表示所有的PDBS。

ALLEXCEPT 表示需要排除的PDBS。

如:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
ALTERPLUGGABLE
DATABASE pdb1, pdb2 OPEN READ ONLY FORCE;
 
ALTERPLUGGABLE
DATABASE pdb1, pdb2 CLOSE IMMEDIATE;
 
 
 
ALTERPLUGGABLE
DATABASE ALL OPEN;
 
ALTERPLUGGABLE
DATABASE ALL CLOSE IMMEDIATE;
 
 
 
ALTERPLUGGABLE
DATABASE ALL EXCEPT pdb1 OPEN;
 
ALTERPLUGGABLE
DATABASE ALL EXCEPT pdb1 CLOSE IMMEDIATE;

示例:

?
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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
SQL>alter
session set container=CDB$ROOT;
 
Sessionaltered.
 
 
 
SQL>select
con_id, dbid, guid, name , open_mode from v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
--------------------
-------------------------------- --------------- ----------
 
2

4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED READ ONLY
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA READ WRITE
 
 
 
SQL>ALTER
PLUGGABLE DATABASE ALL CLOSE ;
 
Pluggabledatabase
altered.
 
 
 
SQL>select
con_id, dbid, guid, name , open_mode from v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
--------------------
-------------------------------- --------------- ----------
 
2

4088301206F7C1E3C96BBF0585E0430A01A8C05459 PDB$SEED READ ONLY
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787PDBCNDBA MOUNTED
 
 
 
SQL>alter
session set container=pdbcndba;
 
 
 
Sessionaltered.
 
 
 
SQL>ALTER
PLUGGABLE DATABASE OPEN;
 
 
 
Pluggabledatabase
altered.
 
 
 
SQL>
select con_id, dbid, guid, name , open_modefrom v$pdbs;
 
 
 
CON_ID
DBID GUID NAME OPEN_MODE
 
--------------------
-------------------------------- --------------- ----------
 
3

426143573

F7C209EB1DFC0854E0430A01A8C0B787PDBCNDBA READ WRITE

3 设置Pluggable Database (PDB) 的自动startup

默认情况下,在CDB 启动的时候,all 的PDB 都是mount状态,也没有默认的机制,在CDB启动时自动启动PDB。

但这里可以通过触发器来实现PDB的自动open:

?
1
2
3
4
5
6
7
8
9
10
11
CREATEOR
REPLACE TRIGGER open_pdbs
 
AFTER
STARTUP ON DATABASE
 
BEGIN
 
EXECUTE
IMMEDIATE
'ALTERPLUGGABLE
DATABASE ALL OPEN'
;
 
END
open_pdbs;
 
/

示例:

?
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
SQL>show
con_name
 
 
 
CON_NAME
 
------------------------------
 
PDBCNDBA
 
SQL>alter
session set container=CDB$ROOT;
 
 
 
Sessionaltered.
 
 
 
SQL>CREATE
OR REPLACE TRIGGER open_pdbs
 
2

AFTER STARTUP ON DATABASE
 
3

BEGIN
 
4

EXECUTE IMMEDIATE
'ALTER
PLUGGABLE DATABASE ALL OPEN'
;
 
5

ENDopen_pdbs;
 
6

/
 
 
 
Triggercreated.

Oracle12cCDB和PDB数据库的启动与关闭说明的更多相关文章

  1. Oracle12c CDB和PDB数据库的启动与关闭说明

    Oracle 12c中,增加了可插接数据库的概念,即PDB,允许一个数据库容器(CDB)承载多个可插拔数据库(PDB). CDB全称为Container Database,中文翻译为数据库容器,PDB ...

  2. RAC 数据库的启动与关闭

    RAC数据库与单实例的差异主要表现在多个实例通过集群件来统一管理共享的资源.因此原有的单实例的管理方式,如数据库.监听器等的关闭启动等可以使用原有的方式进行,也可以通过集群管理工具,命令行来集中管理, ...

  3. Oracle常用命令13(数据库的启动、关闭)

    数据库的启动.关闭 数据库的启动:安装启动.非安装启动.共享启动.独占启动.约束启动.强制启动 --不登陆的方式进入 Sqlplus /nolog 安装启动: Startup {pfile=<f ...

  4. 深刻理解Oracle数据库的启动和关闭 .

    Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对于大多数Oracle DBA来说,启动和 ...

  5. Oracle数据库的启动和关闭

    深刻理解Oracle数据库的启动和关闭 Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对 ...

  6. oracle_深刻理解数据库的启动和关闭

    Oracle数据库提供了几种不同的数据库启动和关闭方式,本文将详细介绍这些启动和关闭方式之间的区别以及它们各自不同的功能. 一.启动和关闭Oracle数据库 对于大多数Oracle DBA来说,启动和 ...

  7. Oracle日常运维操作总结-数据库的启动和关闭

    下面是工作中对Oracle日常管理操作的一些总结,都是一些基本的oracle操作和SQL语句写法,在此梳理成手册,希望能帮助到初学者(如有梳理不准确之处,希望指出). 一.数据库的启动和关闭 1.1 ...

  8. oracle数据库实例启动与关闭

    区分数据库与实例:实例是指各种内存结构和服务进程,数据库是指基于磁盘存储的数据文件.控制文件.参数文件.日志文件和归档日志文件组成的物里文件集合. 数据库实例启动: startup [nomount ...

  9. Oracle数据库的启动与关闭

    一.概述: Oracle数据库的启动分为启动数据库实例.装载数据库和打开数据库3个过程,对应数据库的3种模式. 启动数据库实例:根据数据库初始化参数文件中参数设置,在内存中为数据库分配SGA.PGA等 ...

随机推荐

  1. svn--备忘

  2. Kafka API使用

  3. openstack部署glance

    一.建立glance数据库并且给权限设置第三方登录 mysql -uroot -p0330 CREATE DATABASE glance; GRANT ALL PRIVILEGES ON glance ...

  4. Kubernetes-kubectl The connection to the server localhost:8080 was refused -did you specify

    今天在Kubernetes的从节点上运行命令[kubectl]出现了如下错误: [root@k8snode1 kubernetes]# kubectl get pod The connection t ...

  5. phpstudy批量getshell工具

    phpstudy批量getshell工具,最新phpstudygetshell,配合精确采集实现每天轻松上万! 详情可加QQ:1743685523

  6. 【并行计算-CUDA开发】warp是调度和执行的基本单位而harf-warp为存储器操作基本单位

    1.在用vs运行cuda的一些例子时,在编译阶段会报出很多警告: warning C4819 ...... 解决这个警告的方法是打开出现warning的文件,Ctrl+A全选,然后在文件菜单:file ...

  7. 深入理解C语言-接口封装设计思想

    断层思维 在设计时候,不需要知道实现,只需要知道如何使用 接口设计的设计思路 Sckclient客户端api模型 第一套API (*.h) #ifndef _SCK_CLINT_H_ #define ...

  8. new与malloc有什么区别

    转自http://www.cnblogs.com/QG-whz/p/5140930.html 前言 几个星期前去面试C++研发的实习岗位,面试官问了个问题: new与malloc有什么区别? 这是个老 ...

  9. pycharm 安装好,只要三部! 超级简单教程!

    pycharm的安装,确实比较麻烦,所以特意做了一期简单版本的安装教程,跟着教程走...只要三部! →下载 链接:https://pan.baidu.com/s/1JxZgAhPVKAIoM1_jpD ...

  10. 在使用selenium时出现FileNotFoundError: [WinError 2] 系统找不到指定的文件。

    今天在使用selenium出现这样的错: Traceback (most recent call last): File "E:\python\lib\site-packages\selen ...