ホームページ > データベース > Oracle > Oracleコンテナデータベースの導入と利用の分析例

Oracleコンテナデータベースの導入と利用の分析例

WBOY
リリース: 2022-07-11 13:35:21
転載
2931 人が閲覧しました

この記事では、Oracle に関する関連知識を提供し、主に Oracle コンテナ データベースの基本知識やコンテナ データベースのインストールなど、コンテナ データベースのインストールと使用に関連する問題を整理します。コンテナデータベースの機能などについて一緒に見ていきましょう。

Oracleコンテナデータベースの導入と利用の分析例

推奨チュートリアル: 「Oracle ビデオ チュートリアル

Oracle 19c のインストールと使用

Oracle コンテナ データベース基本知識

コンテナ データベース (プラガブル データベースとも呼ばれ、マルチテナント コンテナ データベースとも呼ばれます)
Oracle Multitenant Container Database (CDB)
CDB の紹介Oracle 12C では、この機能は、1 つ以上のプラガブル データベース を収容できるデータベース を指します。この機能により、CDB コンテナ データベースで複数のデータベースを作成および保守できます。CDB で作成されるデータベースは次のとおりです。 PDB単体で使用する場合は通常のデータベースと変わりません CDB ルート コンテナ データベースの主な機能は、関連するすべての PDB のメタデータを収容し、CDB 内のすべての PDB を管理することです。
つまり、コンテナをCDB、コンテナ内のサブデータベースをPDBと呼びます。

コンテナ データベースの構成

Oracleコンテナデータベースの導入と利用の分析例##2.1.1ROOT

ルート コンテナ データベースは、CDB 環境のルート データベースです。マスター データ ディクショナリ ビュー

が含まれます。これには、ルート コンテナに関連するメタデータと、CDB

に含まれるすべての PDB 情報が含まれます。 CDB 環境では CDB$ROOT として識別されます。 各 CDB 環境に存在できるルート コンテナ データベースは 1 つだけです。 2.1.2CDB シード

CDB シードは PDB のシードであり、データ ファイルを提供し、CDB 環境では PDB

SEED として識別されます。新しい PDB** を作成するためのテンプレートです。PDB に接続できます ​ ##################シード######、###### ##∗chuangbuildPDBモジュール ボード##∗,あなたはと接続できます#P DBSEED がありますが、PDB$SEED は 読み取り専用であり、変更できないため、何も実行できません2.1.3PDBs PDB データベース。CDB 環境では、各 PDB は独立して存在します。基本的には従来の Oracle データベースと同じです。各 PDB には独自のデータ ファイルとオブジェクトがあります。唯一の違いは、PDB は CDB に接続したり、CDB から取り外したりできることですが、どの時点でも PDB を CDB から取り外したり接続したりする必要があり、ユーザーは、PDB に接続するときにルート コンテナを感じないことです。 PDB: 他の PDB の存在。

2.1.4アプリケーションコンテナ

Oracleは12cR2バージョンでコンテナ機能を強化しており、CDBルートコンテナにアプリケーションルートというコンテナを作成し、その中に複数の依存関係を作成することもできます。アプリケーション ルートのアプリケーション PDB は次のとおりです。
Oracleコンテナデータベースの導入と利用の分析例
簡単に言えば、 コンテナはコンテナ も作成できます。

ルート環境のユーザー

以前のバージョンでは、1 つの PDB に複数のユーザーが存在し、各ユーザーは独自の表領域を持つことができましたが、CDB レベルまでは、ユーザーは 2 つに分割されていました。カテゴリ:
パブリック ユーザーとローカル ユーザー。

  • パブリック ユーザー
    パブリック ユーザーは、ルート データベースとすべての PDB データベースに存在するユーザーです。パブリック ユーザーはルート コンテナで作成する必要があり、このユーザーはすべての既存 PDB で自動的に作成され、パブリック ユーザー ID は c## または C## で始まる必要があります。sys および system ユーザーは、CDB 環境で Oracle によって自動的に作成されるパブリック ユーザーです。
  • パブリック ユーザー
    ローカル ユーザーは、PDB で作成された通常のユーザーを指します。このユーザーは、作成された PDB にのみ存在し、PDB ではローカル ユーザーのみを作成できます。

PDB には以前のデフォルトの scott ユーザー が存在しないため、再作成する必要があることにも言及する価値があります。 また、
は、「sqlplus/as sysdba」ログインを通じて CDB に接続されています。 (重要なポイント)

コンテナ データベースのインストールと使用

インストール

前バージョンのインストールの 4 番目の手順でコンテナ データベースのチェックを外すことを忘れませんか?


Oracleコンテナデータベースの導入と利用の分析例 あとは、コンテナ データベースを作成するためにチェックするだけです;

共通コマンド

インストール後、sqlplus を開いて管理者アカウントでログインします


sqlplus/as sysdba

現在のコンテナの表示

show con_name;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 現在のコンテナがルート コンテナであることがわかります。

データベースが CDB であるかどうかを確認してください

select name,cdb,open_mode,con_id from v$database;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 Open_mode が読み取りおよび書き込み権限である

CDB の PDB 情報を確認してください

show pdbs;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 内部にシードとデフォルトの PDB が表示されます。

作成した PDB データベースの起動と停止

まず、使用する PDB にセッションを切り替えます。

alter session set container = orclpdb;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 ここには 2 つのコマンド セットがあります
オンにする:

alter pluggable database pdb1 open;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 オフにする:

alter pluggable database pdb1 close;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 従来のシャットアップとシャットダウン
開く:

shartup;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 閉じる:

shutdown immediate;
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例 SHUTDOWN のいくつかのパラメーターと意味を次に示します。

  • 通常シャットダウン: デフォルトのシャットダウン モードでは、a. 新しいデータベース接続が許可されません。b. すべての接続が切断された場合にのみ閉じることができ、効率が低くなります
  • 即時シャットダウン: 一般的に使用されるシャットダウン方法、a. 新しい接続の作成は許可されません; b. すでに作成された接続に未完了の SQL ステートメントがある場合は、それらの完了を待ちます。そうでない場合は、すぐに切断します ;c. すべてのコミットされていないトランザクションはロールバックされます
  • shutdowntransactional: 使用率は非常に低いです
  • shutdown abort : a. コミットされていないトランザクションはロールバックされません (ロール) b. すべての SQL 操作を終了します; c. すべての接続が切断されます。データベースはすぐにシャットダウンされますが、次にデータベースを開くときにインスタンスの回復が必要になり、起動が遅くなり、ロールバック セグメント データとデータ ファイルが不整合になる可能性があります。
CDB と PDB の切り替え

alter session set container=ORCLPDB; --PDBalter session set container=CDB$ROOT;--CDBshow con_name   --查看当前容器
ログイン後にコピー

plsql を使用した使用

ただし、私たちは日常的に plsql を使用しており、通常使用しているものとはいくつかの違いがあります。 。 違い。

打开PDB

首先,还是用管理员账户登录(此时数据库选项里是没有我们想用的PDB的)
Oracleコンテナデータベースの導入と利用の分析例
打开一个命令窗口吗,看一下当前CDB里PDB的信息
Oracleコンテナデータベースの導入と利用の分析例
Oracleコンテナデータベースの導入と利用の分析例
利用上面刚学的命令,切换会话,打开想用的PDB,自己做哦

创建用户并授权

上面说了,PDB里是没有我们所知道的Scott用户的,这里需要我们重新创建他

create user scott identified by tiger;--给用户授予权限 grant connect,resource,dba to scott; --删除用户drop user truedata scott;
ログイン後にコピー

创建表空间,为用户指定表空间及为用户授予权限都与以前的使用方式一样。

配置

想要用plsql登录PDB,我们需要更改一个配置文件
Oracleコンテナデータベースの導入と利用の分析例
安装目录下的tnsnames.ora文件,复制里面的ORCL,更改名字即可
Oracleコンテナデータベースの導入と利用の分析例
然后用plsql登录即可
Oracleコンテナデータベースの導入と利用の分析例
单个PDB的使用,与我们日常所用的数据库并无区别

如果连接可插拔数据库时出现:
ORACLE 正在初始化或关闭。
这个错误,参考我的博客:
链接: PLSQL报ORA-01033: ORACLE正在初始化或关闭的解决方法
或者可能是PDB没打开,参考3.2.4打开即可。

容器数据库的创建

  PDB数据库的创建可以从现存的数据库中复制数据文件,包括种子容器、可插拔数据库、non-CDB数据库,创建时可以使用CREATE PLUGGABLE、RMAN、DBCA以及EM等。
  在12.1版本中在创建PDB时,Source PDB必须处于read only状态,在12.2版本中,因为undo local mode新特性的推出,在创建PDB时,Source PDB在read write状态,依然可以创建。
  另外在12.2版本中Oracle推出了refresh PDB特性,具有对Source PDB进行增量同步的功能。

创建方式

使用CREATE PLUGGABLE命令可以使用以下资源创建PDB:
CDB seed (PDB$SEED)
克隆已经存在的PDB
Local PDB
Remote PDB
non-CDB数据库

	如果把数据库从11g 升级到12c,或者在12c中创建的,就是NON CDB,那么这样的数据库就是普通的单实例,和12c 之前的数据库没有区别
ログイン後にコピー

链接: Oracle 12c系列(七)| Non-CDB转换为PDB

拔下的PDB

使用DBCA可以使用以下资源创建PDB:
DBCA也就是我们常用的数据库配置工具、图形化界面
CDB seed (PDB$SEED)
RMAN备份
拔下的PDB
示例:(这里只演示使用create pluggable database命令方式创建PDB)

使用CDB seed创建PDB

Oracleコンテナデータベースの導入と利用の分析例

  1. 在SQL*Plus中输入CREATE PLUGGABLE DATABASE语句
    (这里创建为ypdb1的pdb,管理用户为ypdb1)
CREATE PLUGGABLE DATABASE ypdb1 ADMIN USER ypdb1 IDENTIFIED BY oracle
STORAGE (MAXSIZE 2G)DEFAULT TABLESPACE ypdb1
DATAFILE '/u01/app/oracle/oradata/ora12c/ypdb1/ypdb01.dbf' SIZE 100M AUTOEXTEND ONPATH_PREFIX = '/u01/app/oracle/oradata/ora12c/ypdb1/'FILE_NAME_CONVERT = ('/u01/app/oracle/oradata/ora12c/pdbseed', '/u01/app/oracle/oradata/ora12c/ypdb1');
ログイン後にコピー

Oracleコンテナデータベースの導入と利用の分析例

  1. 语句执行完毕之后查看创建完成的PDB:
sys. ora12c>show pdbs
CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------
 2 PDB$SEED                       READ ONLY  NO
 3 YPDB1                          MOUNTED
ログイン後にコピー

克隆已经存在的PDB

这种方式可以通过使用当前CDB中的其他PDB,以及复制远端CDB中的PDB,还可以复制non-CDB数据库创建成PDB。

Clone a Local PDB
在Clone本地PDB时需要注意一下几点:
使用的用户必须拥有’CREATE PLUGGABLE DATABASE’的权限(测试里使用sys用户)
源PDB不可以是关闭状态
如果CDB为shared undo,PDB必须为READ-ONLY状态
如果CDB不是归档模式,那么PDB必须为READ-ONLY状态

	(说明:如果是Oracle Database 版本为12.1,那么PDB只能为READ-ONLY状态,因在12.1中undo模式,还只能选择shared undo。)
ログイン後にコピー
sys. ora12c>show pdbs
CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------
 2 PDB$SEED                       READ ONLY  NO
 3 YPDB1                          READ WRITE NOsys. ora12c>
ログイン後にコピー

这里使用YPDB1做为源PDB,创建的PDB为YPDB2。
(1) 检查是否为shared undo模式

COL PROPERTY_NAME FOR A30
COL PROPERTY_VALUE FOR A30SELECT property_name, property_valueFROM database_propertiesWHERE property_name='LOCAL_UNDO_ENABLED';PROPERTY_NAME                  PROPERTY_VALUE------------------------------ ------------------------------LOCAL_UNDO_ENABLED             TRUE
ログイン後にコピー

(2) 检查是否未archivelog模式

sys. ora12c>ARCHIVE LOG LISTDatabase log mode              Archive ModeAutomatic archival             Enabled
Archive destination            /u01/app/oracle/recovery/ora12c/arch
Oldest online log sequence     21Next log sequence to archive   23Current log sequence           23sys. ora12c>
ログイン後にコピー

(3) 创建验证数据

zhaoweiqing. ypdb1>CONN /AS SYSDBA
Connected.sys. ora12c>conn zhaoweiqing/zhaoweiqing@ypdb1Connected.zhaoweiqing. ypdb1>SELECT COUNT(*) FROM t;COUNT(*)----------22198Elapsed: 00:00:00.01zhaoweiqing. ypdb1>
ログイン後にコピー

(4) 执行CREATE PLUGGABLE DATABASE语句(这里使用sys用户连接根容器)

CREATE PLUGGABLE DATABASE ypdb2 FROM ypdb1
PATH_PREFIX = '/u01/app/oracle/oradata/ora12c/ypdb2/'FILE_NAME_CONVERT = ('/u01/app/oracle/oradata/ora12c/ypdb1/', '/u01/app/oracle/oradata/ora12c/ypdb2/')SERVICE_NAME_CONVERT = ('ypdb1t','ypdb2t');
ログイン後にコピー

(5) 查看创建完成的YPDB2

sys. ora12c>show pdbs
CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------
 2 PDB$SEED                       READ ONLY  NO
 3 YPDB1                          READ WRITE NO
 4 YPDB2                          MOUNTED
sys. ora12c>SELECT pdb_id, pdb_name, con_uid, status, creation_scn, con_id FROM cdb_pdbs;PDB_ID PDB_NAME                CON_UID STATUS     CREATION_SCN     CON_ID---------- -------------------- ---------- ---------- ------------ ----------
 2 PDB$SEED             1453953285 NORMAL              213          2
 3 YPDB1                2376019304 NORMAL           697945          3
 4 YPDB2                3908707960 NEW              707501          4Elapsed: 00:00:00.02sys. ora12c>
ログイン後にコピー

(6) 检查数据文件

sys. ora12c>ALTER PLUGGABLE DATABASE YPDB2 OPEN;Pluggable database altered.Elapsed: 00:00:14.02sys. ora12c>SELECT con_id, tablespace_name, file_name FROM cdb_data_files WHERE con_id=4;CON_ID TABLESP FILE_NAME------ ------- ---------------------------------------------------------4 SYSTEM  /u01/app/oracle/oradata/ora12c/ypdb2/system01.dbf4 SYSAUX  /u01/app/oracle/oradata/ora12c/ypdb2/sysaux01.dbf4 DEFTBS  /u01/app/oracle/oradata/ora12c/ypdb2/deftbs01.dbf4 USERTBS /u01/app/oracle/oradata/ora12c/ypdb2/usertbs01.dbf4 UNDO_1  /u01/app/oracle/oradata/ora12c/ypdb2/system01_i1_undo.dbf4 YPDB1   /u01/app/oracle/oradata/ora12c/ypdb2/ypdb01.dbf6 rows selected.Elapsed: 00:00:00.01sys. ora12c>
ログイン後にコピー

(7) 检查service_name

sys. ora12c>SELECT service_id, name, network_name, enabled, pdb, con_id FROM cdb_services;SERVICE_ID NAME                NETWORK_NAME         ENA PDB           CON_ID---------- ------------------- -------------------- --- --------- ----------
 1 SYS$BACKGROUND                           NO  CDB$ROOT           1
 2 SYS$USERS                                NO  CDB$ROOT           1
 3 ora12c.linux.com    ora12c.linux.com     NO  CDB$ROOT           1
 6 ypdb1.linux.com     ypdb1.linux.com      NO  YPDB1              3
 1 ypdb1t              ypdb1t               NO  YPDB1              3
 1 ypdb2t              ypdb2t               NO  YPDB2              4
 2 ypdb2.linux.com     ypdb2.linux.com      NO  YPDB2              47 rows selected.Elapsed: 00:00:00.00sys. ora12c>
ログイン後にコピー

源PDB中的service_name已经被更改指定的service_name.

(8) 检查验证数据

sys. ora12c>conn zhaoweiqing/zhaoweiqing@ypdb2Connected.zhaoweiqing. ypdb2>SELECT COUNT(*) FROM t;COUNT(*)----------22198Elapsed: 00:00:00.11zhaoweiqing. ypdb2>
ログイン後にコピー

克隆远程PDB

Oracleコンテナデータベースの導入と利用の分析例
Clone远端PDB时需要注意以下几点:

如果PDB被Clone到的CDB的字符集不是AL32UTF8,那么源与目标字符集必须兼容。

源端与目标端的字节顺序必须相同。

连接的用户在CDB中必须拥有’CREATE PLUGGABLE DATABASE’的权限。

源PDB不可以是关闭状态。

如果远端CDB为shared undo,源PDB必须为READ-ONLY状态。

如果远端CDB不是归档模式,源PDB必须为READ-ONLY状态。

这里测试将win平台ORA12CW中的PDB(ORA12CWPDB)复制到Linux的,目标PDB为PDB2。

(1) 查看源端与目标的字符集

col parameter for a30
col value for a30select * from nls_database_parameters where parameter='NLS_CHARACTERSET'or parameter='NLS_LANGUAGE' or parameter='NLS_NCHAR_CHARACTERSET';```**(2) 查看源端与目标端字节顺序**

```sqlcol platform_name for a40SELECT d.inst_id, t.platform_id, t.platform_name, t.endian_format, d.name FROM v$transportable_platform t, gv$database dWHERE t.platform_name = d.platform_name;
ログイン後にコピー

(3) 查看源端归档模式

archive log list
ログイン後にコピー

(4) 查看源端undo模式

SELECT property_name, property_valueFROM database_propertiesWHERE property_name='LOCAL_UNDO_ENABLED';
ログイン後にコピー

(5) 目标端创建dblink

CREATE DATABASE LINK ora12cw CONNECT TO system IDENTIFIED BY oracle USING 'ORA12CW';
ログイン後にコピー

(6) 运行CREATE PLUGGABLE DATABASE语句进行复制PDB

CREATE PLUGGABLE DATABASE pdb2 FROM ORA12CWPDB@ora12cwPATH_PREFIX = '/u01/app/oracle/oradata/ora12cl/pdb2/'FILE_NAME_CONVERT = ('D:\U01\APP\ORACLE\ORADATA\ORA12CW\ORA12CWPDB\', '/u01/app/oracle/oradata/ora12cl/pdb2/');
ログイン後にコピー

(7) 创建完成后目标端查看PDB2

sys. ora12cl>show pdbs
CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------
 2 PDB$SEED                       READ ONLY  NO
 4 PDB2                           MOUNTED 5 PDB1                           MOUNTED
sys. ora12cl>SELECT pdb_id, pdb_name, con_uid, status, creation_scn, con_id FROM cdb_pdbs;PDB_ID PDB_NAME                CON_UID STATUS     CREATION_SCN     CON_ID---------- -------------------- ---------- ---------- ------------ ----------
 2 PDB$SEED             3409233005 NORMAL          1408788          2
 4 PDB2                 2218727525 NEW             1824437          4
 5 PDB1                 1058019921 NORMAL          1535445          5Elapsed: 00:00:00.00sys. ora12cl>
ログイン後にコピー

(8) 目标查看数据文件

sys. ora12cl>alter pluggable database pdb2 open;Pluggable database altered.Elapsed: 00:00:14.02sys. ora12cl>SELECT con_id, tablespace_name, file_name FROM cdb_data_files WHERE con_id=4;CON_ID TABLESPACE_NAME FILE_NAME------ --------------- --------------------------------------------------4 SYSTEM          /u01/app/oracle/oradata/ora12cl/pdb2/SYSTEM01.DBF4 SYSAUX          /u01/app/oracle/oradata/ora12cl/pdb2/SYSAUX01.DBF4 UNDOTBS1        /u01/app/oracle/oradata/ora12cl/pdb2/UNDOTBS01.DBF4 USERS           /u01/app/oracle/oradata/ora12cl/pdb2/USERS01.DBF
Elapsed: 00:00:00.00sys. ora12cl>
ログイン後にコピー

克隆远端的PDB成功。

克隆本地PDB

在克隆已有的PDB或者non CDB时,我们也可以将克隆语句中加入NO DATA子句,在使用NO DATA子句时,仅仅会克隆源PDB中的模型定义,并不会克隆PDB中的数据。(Oracle数据库内自动创建的schemas下的对象会被成功克隆,而用户创建的schemas下的对象仅仅会克隆对象的定义结构)。

测试克隆本地PDB时使用no data子句

这里将WOQUPDB克隆为PDBTEST.

(1)源PDB

sys. woqu>show pdbs
CON_ID CON_NAME                       OPEN MODE  RESTRICTED---------- ------------------------------ ---------- ----------
 2 PDB$SEED                       READ ONLY  NO
 3 WOQUPDB                        READ WRITE NOsys. woqu>COL PROPERTY_NAME FOR A30
sys. woqu>COL PROPERTY_VALUE FOR A30
sys. woqu>
ログイン後にコピー

(2)检查UNDO模式及归档模式

sys. woqu>SELECT property_name, property_value2  FROM database_properties3  WHERE property_name='LOCAL_UNDO_ENABLED';PROPERTY_NAME                  PROPERTY_VALUE------------------------------ ------------------------------LOCAL_UNDO_ENABLED             TRUEElapsed: 00:00:00.04sys. woqu>sys. woqu>archive log listDatabase log mode              Archive ModeAutomatic archival             Enabled
Archive destination            USE_DB_RECOVERY_FILE_DEST
Oldest online log sequence     7Next log sequence to archive   9Current log sequence           9sys. woqu>
ログイン後にコピー

(3)创建测试数据表t,注意这里的t表位于sys用户下

05:51:10 sys. woqupdb>create table t as select * from dba_objects where rownumselect count(*) from t;COUNT(*)----------10Elapsed: 00:00:00.0105:52:50 sys. woqupdb>
ログイン後にコピー

表t中共有10条数据。
(4)创建测试数据表t_tab,注意这里的t表位于zhaoweiqing用户下

05:51:46 zhaoweiqing. woqupdb>create table t_tab as select * from dba_objects where rownumselect count(*) from t_tab;COUNT(*)----------999Elapsed: 00:00:00.0105:52:19 zhaoweiqing. woqupdb>
ログイン後にコピー

(5)使用create pluggable database + NO DATA子句创建pdb:pdbtest

sys. woqu>CREATE PLUGGABLE DATABASE pdbtest FROM woqupdb NO DATA2  PATH_PREFIX = '/u01/app/oracle/oradata/woqu/pdbtest'3  FILE_NAME_CONVERT = ('/u01/app/oracle/oradata/woqu/woqupdb', '/u01/app/oracle/oradata/woqu/pdbtest');Pluggable database created.Elapsed: 00:00:09.35sys. woqu>
ログイン後にコピー

(6)检查克隆完成的pdbtest

sys. woqu>show pdbs
CON_ID CON_NAME    OPEN MODE  RESTRICTED---------- ----------- ---------- ----------
 2 PDB$SEED    READ ONLY  NO
 3 WOQUPDB     READ WRITE NO
 5 PDBTEST     MOUNTED
sys. woqu>SELECT pdb_id, pdb_name, con_uid, status, creation_scn, con_id FROM cdb_pdbs;PDB_ID PDB_NAME       CON_UID STATUS     CREATION_SCN     CON_ID---------- ----------- ---------- ---------- ------------ ----------
 3 WOQUPDB     1167267009 NORMAL          1443334          3
 2 PDB$SEED     399989944 NORMAL          1408751          2
 5 PDBTEST     3356573055 NEW             1956581          5Elapsed: 00:00:00.05sys. woqu>alter pluggable database pdbtest open;Pluggable database altered.Elapsed: 00:00:07.09sys. woqu>show pdbs
CON_ID CON_NAME    OPEN MODE  RESTRICTED---------- ----------- ---------- ----------
 2 PDB$SEED    READ ONLY  NO
 3 WOQUPDB     READ WRITE NO
 5 PDBTEST     READ WRITE NOsys. woqu>SELECT pdb_id, pdb_name, con_uid, status, creation_scn, con_id FROM cdb_pdbs;PDB_ID PDB_NAME     CON_UID STATUS CREATION_SCN     CON_ID---------- --------- ---------- ------ ------------ ----------
 3 WOQUPDB   1167267009 NORMAL      1443334          3
 2 PDB$SEED   399989944 NORMAL      1408751          2
 5 PDBTEST   3356573055 NORMAL      1956581          5Elapsed: 00:00:00.02sys. woqu>
ログイン後にコピー

(7)查看测试数据

sys. woqu>alter session set container=pdbtest;Session altered.Elapsed: 00:00:00.07sys. woqu>show user con_idUSER is "SYS"CON_ID------------------------------5sys. woqu>select count(*) from t;COUNT(*)----------10Elapsed: 00:00:00.00sys. woqu>select count(*) from zhaoweiqing.t_tab;COUNT(*)----------
 0Elapsed: 00:00:00.02sys. woqu>
ログイン後にコピー

通过测试可以看到sys下的对象中的数据依然克隆成功,而自建用户下的对象中数据并没有跟着一起克隆。

推荐教程:《Oracle视频教程

以上がOracleコンテナデータベースの導入と利用の分析例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:csdn.net
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート