在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. Python新利器之pipenv

    前言 之前学习异步asyncio库的时候,因为asyncio库支持Python3.5以上的版本,而我的Ubuntu14.04只有Python3.4,虽然下载了Python3.6,但是想直接利用ipyt ...

  2. Ansible-galera

    在四台虚拟机上都安装好docker 一.控制节点 1. 域名解析 [root@d ansible]# vim /etc/hosts [root@d ansible]# scp /etc/hosts n ...

  3. 转:获取windows凭证管理器明文密码

    1.运行cmdkey /list查看windows保存凭证 方法1.mimikaz mimikatz vault::cred 2.利用powershell尝试获取 windows 普通凭据类型中的明文 ...

  4. ParallelForTransform作业

    ParallelForTransform作业是另一种ParallelFor作业 ; 专为在变形上操作而设计. 注意:ParallelForTransform作业是Unity中用于实现IJobParal ...

  5. C#中?的相关使用

    C#中?的相关使用 今天看了几篇博客,学习了一下与?相关的使用,大致分为一下几种: 1. 可空类型 看标题就能够很好的理解这个概念:可以为空的类型.而在C#中可以为空也就是null的类型,都是引用类型 ...

  6. 关于lombok插件的使用,强大的简化代码工具

    关于下载和安装lombok插件,过程特别简单,可以参考: https://blog.csdn.net/longloveqing/article/details/81539749 安装好后,下面介绍下l ...

  7. strcpy函数内存分析

    void strcpy(char* strDest, char* strSrc) { while((*strDest++ = *strSrc++) != '\0'); } 看上面这段代码,只有一条语句 ...

  8. IntelliJ IDEA 2019.2.1 破解教程, 最新激活码(激活到2089年8月,亲测有效,持续更新中...)

    当前最新版本 IDEA 2019.2.1 本来笔者这边是有个正版激活码可以使用的,但是,2019.9月3号的时候,一些小伙伴反映这个注册码已经失效了,于是拿着自己的 IDEA, 赶快测试了一下,果不其 ...

  9. SpringCloud学习(二)服务消费者(rest+ribbon)(Finchley版本)

    在微服务架构中,业务都会被拆分成一个独立的服务,服务与服务的通讯是基于http restful的.Spring cloud有两种服务调用方式,一种是ribbon+restTemplate,另一种是fe ...

  10. Mac下使用sshpass让iterm2支持多ssh登录信息保存

    mac下没有xshell等连接linux服务器的工具,当需要管理的服务器越来越多之后,密码管理就成了一个很头疼的问题,每次都需要去复制粘贴密码,浪费了很多时间,在网上查了不少资料,发现mac下可以使用 ...