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

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

1. Container Database (CDB)

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

SHUTDOWN [IMMEDIATE | ABORT]

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

[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>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:

SQL>shutdown immediate

Database closed.
Database dismounted.
ORACLE instance shut down.

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

SQL>startup

ORACLE instance started.
TotalSystem Global Area 1269366784 bytes
FixedSize 2287912 bytes
VariableSize 788530904 bytes
DatabaseBuffers 469762048 bytes
RedoBuffers 8785920 bytes
Database mounted.
Database opened.

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,具体语法和普通实例一样:

STARTUP FORCE;

STARTUP OPEN READ WRITE [RESTRICT];

STARTUP OPEN READ ONLY [RESTRICT];

STARTUP UPGRADE;

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;

Session altered.

SQL>startup

Pluggable Database 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

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

2.2 使用ALTER PLUGGABLE DATABASE命令

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

ALTER PLUGGABLE DATABASE OPEN READ WRITE [RESTRICTED] [FORCE];

ALTER PLUGGABLE DATABASE OPEN READ ONLY [RESTRICTED] [FORCE];

ALTER PLUGGABLE DATABASE OPEN UPGRADE [RESTRICTED];

ALTER PLUGGABLE DATABASE CLOSE [IMMEDIATE];

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

ALTER PLUGGABLE DATABASE <pdd-name-clause> OPEN READ WRITE [RESTRICTED][FORCE];

ALTER PLUGGABLE DATABASE <pdd-name-clause> OPEN READ ONLY [RESTRICTED] [FORCE];

ALTER PLUGGABLE DATABASE <pdd-name-clause> OPEN UPGRADE [RESTRICTED];

ALTER PLUGGABLE DATABASE <pdd-name-clause> CLOSE [IMMEDIATE];

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

ALL:表示所有的PDBS。
ALLEXCEPT:表示需要排除的PDBS。

如:

ALTER PLUGGABLE DATABASE pdb1, pdb2 OPEN READ ONLY FORCE;

ALTER PLUGGABLE DATABASE pdb1, pdb2 CLOSE IMMEDIATE;

ALTER PLUGGABLE DATABASE ALL OPEN;

ALTER PLUGGABLE DATABASE ALL CLOSE IMMEDIATE;

ALTER PLUGGABLE DATABASE ALL EXCEPT pdb1 OPEN;

ALTER PLUGGABLE DATABASE ALL EXCEPT pdb1 CLOSE IMMEDIATE;

示例:

SQL>alter session set container=CDB$ROOT;

Session 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 F7C209EB1DFC0854E0430A01A8C0B787 PDBCNDBA READ WRITE

SQL>ALTER PLUGGABLE DATABASE ALL CLOSE ;

Pluggable database 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;

Session altered.

SQL>ALTER PLUGGABLE DATABASE OPEN;

Pluggable database 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:

CREATEOR REPLACE TRIGGER open_pdbs

AFTER STARTUP ON DATABASE

BEGIN

    EXECUTE IMMEDIATE 'ALTER PLUGGABLE DATABASE ALL OPEN';

END open_pdbs;

/

示例:

SQL>show con_name

CON_NAME
------------------------------
PDBCNDBA

SQL>alter session set container=CDB$ROOT;

Session altered.

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

Trigger created.
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java通过Jacob可以轻松调用Bartender。Bartender是一款强大的条码标签打印软件,而Jacob是连接Java和Microsoft Office的一种技术。Java可以使用Jacob的API,通过COM接口来调用Bartender的应用程序程序接口(API)。这可以让Java应用程序使用Bartender的打印功能,从而生成和打印条形码标签。最常用的方法是使用Jacob的Dispatch类和Method类,来调用Bartender的API命令,从而实现打印功能。同时,Java和Bartender都支持自定义的脚本和代码,因此可以更加灵活地实现打印的业务逻辑。通过JavaJacob的结合,实现了Bartender和其他应用程序的打印功能的集成,为工业、物流等领域的数据采集和信息管理提供了可靠的技术支持,使得企业的生产管理变得更加高效。 ### 回答2: Bartender是一个条码标签打印软件,而jacobJava COM桥接器,可以将Java程序与COM组件进行通信。使用jacob可以在Java程序中调用Bartender的COM 接口,进而实现打印条码标签等功能。 首先,需要下载jacob库并在Java工程中导入相关的jar包。然后,需要安装Bartender软件并通过其开放的COM接口。对于Bartender的COM接口,需要在Bartender的菜单栏中选择“文件”→“打印”→“COM打印对象设置”来打开COM设置窗口。在其中选择“启用COM对象”并保存。 接下来,在Java程序中实现调用Bartender的步骤如下: 1. 创建jacob的ActiveXComponent对象,指定Bartender的COM对象ID“Bartender.Application”。 2. 使用对象方法调用Bartender的COM接口,例如设置打印模板、设定数据源等。 3. 调用jacob的Variant对象,将参数传递给Bartender的COM接口。 4. 调用jacob的Dispatch.call方法传递方法名和参数,实现调用Bartender的COM接口。 示例代码如下: // 创建ActiveXComponent对象 ActiveXComponent bartender = new ActiveXComponent("Bartender.Application"); // 指定模板和数据源 bartender.invoke("Open", new Variant("标签模板")); bartender.invoke("SetNamedSubStringValue", new Variant("数据源名称"), new Variant("数据源值")); // 设定打印机 bartender.setProperty("Printer", new Variant("打印机名称")); // 执行打印 bartender.invoke("StartPrintJob"); bartender.invoke("PrintOut", new Variant(false)); bartender.invoke("CancelPrintJob"); 通过上述方法,我们可以使用Java程序调用Bartender的COM接口,在Java程序中实现打印标签等功能。需要注意的是,Bartender的COM接口需要有相应的权限才能被调用,因此需要确保用户的权限设置正确。同时,也需要按照Bartender的COM接口文档使用正确的方法和参数,才能成功调用Bartender的接口。 ### 回答3: Java 通过jacob调用Bartender是一个常见的需求,Bartender是一款非常流行的标签设计和打印软件。jacobJavaCOM桥接器,它可以让Java程序通过COM接口调用Windows平台下的各种COM组件,比如Bartender。下面我们将详细介绍Java通过jacob调用Bartender的步骤。 首先我们需要下载jacob,并添加到Java工程的类路径中。接着我们需要在Java程序中编写Bartender调用的代码。在Java程序中,我们可以通过jacob来连接COM对象,后面的操作跟普通的Java操作一样,包括设置打印参数、调用打印方法等等。 下面是一个简单的Java代码示例,展示如何通过jacob调用Bartender: ```java public class BartenderService { private ComServer bartend; public BartenderService(String bartenderPath) { bartend = new ComServer(); if (bartend.init(bartenderPath)) { return; } throw new RuntimeException("failed init bartender"); } public void printLabel(String filePath, String labelName, Map<String,String> fieldValues) { bartend.call("Format.FileOpen", filePath, true, ""); bartend.call("Document.Open", labelName); for (Map.Entry<String,String> entry : fieldValues.entrySet()) { bartend.setProperty("Document.Variables(\"" + entry.getKey() + "\")", entry.getValue()); } bartend.setProperty("Document.PrinterSetup.PrinterName", "your-printer-name"); bartend.call("Document.PrintLabel", 1, 1); } } ``` 在这个代码示例中,我们定义了一个BartenderService类,它初始化时需要传入Bartender的安装路径。在打印标签时,我们会调用printLabel方法,传入标签文件路径、标签名称和打印参数。这个方法会打开文件、打开标签、设置打印参数和变量(即标签中的占位符),最后调用打印方法来完成打印操作。 总的来说,Java通过jacob调用Bartender是非常方便的,只需要简单地编写几十行代码,就可以实现标签的设计和打印。如果您在工作中有相关需求,建议尝试一下这个技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值