溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

關(guān)于在CDB_DATA_FILES視圖中如何查看seed pdb的datafile問題

發(fā)布時間:2020-07-30 20:51:18 來源:網(wǎng)絡(luò) 閱讀:1292 作者:你聽得到 欄目:關(guān)系型數(shù)據(jù)庫

 在oracle 12c多租戶環(huán)境里,我們有時想通過cdb_data_files來查看種子數(shù)據(jù)庫(pdb$seed)的文件信息,會發(fā)現(xiàn)沒有反饋結(jié)果,但你可能會發(fā)現(xiàn)網(wǎng)上有些案例里卻能通過cdb_data_files這個視圖查看到關(guān)于pdb$seed的信息。這是怎么回事呢?

 我在12c幾個版本的reference里沒有找到關(guān)于cdb_data_files的詳細(xì)說明,不過在 Administrator Guide中找到這句話:

 the DBA_PDBS and CDB_DATA_FILES views to show the name and location of each data file for all of the PDBs in a CDB, including the CDB seed.

    這說明cdb_data_files確實有pdb$seed的信息。

    在MOS中,文檔(1940806.1) PDB$SEED Datafiles Not Appear In CDB_DATA_FILES 介紹是參數(shù)EXCLUDE_SEED_CDB_VIEW 的設(shè)置問題。不過對于這個新參數(shù),oracle 12c各個版本的情況都不相同。

1. 首先在oracle 12.1.0.1版本中,沒有參數(shù)EXCLUDE_SEED_CDB_VIEW。因此,你會發(fā)現(xiàn)在這個版本下,你能從cdb_data_files中直接查看到pdb$seed。

SQL> select * from v$version;

BANNER										     CON_ID
-------------------------------------------------------------------------------- ----------
Oracle Database 12c Enterprise Edition Release 12.1.0.1.0 - 64bit Production		  0
PL/SQL Release 12.1.0.1.0 - Production							  0
CORE	12.1.0.1.0	Production								  0
TNS for Linux: Version 12.1.0.1.0 - Production						  0
NLSRTL Version 12.1.0.1.0 - Production							  0

SQL> select file_name from cdb_data_files;

FILE_NAME
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/dbdata/cdb1/system01.dbf
/u01/dbdata/cdb1/sysaux01.dbf
/u01/dbdata/cdb1/undotbs01.dbf
/u01/dbdata/cdb1/users01.dbf
/u01/dbdata/cdb1/pdbseed/system01.dbf
/u01/dbdata/cdb1/pdbseed/sysaux01.dbf
/u01/dbdata/cdb1/pdb1/system01.dbf
/u01/dbdata/cdb1/pdb1/sysaux01.dbf
/u01/dbdata/cdb1/pdb1/SAMPLE_SCHEMA_users01.dbf
/u01/dbdata/cdb1/pdb1/example01.dbf

10 rows selected.
SQL>  select name,value,description from v$parameter where name like '%seed%';

no rows selected

SQL> SELECT   ksppinm, ksppstvl, ksppdesc   FROM   x$ksppi x, x$ksppcv y  WHERE   x.indx = y.indx AND ksppinm like '%seed%'

KSPPINM 		       KSPPSTVL 	    KSPPDESC
------------------------------ -------------------- ------------------------------------------------------------
_deferred_seg_in_seed	       TRUE		    Enable Deferred Segment Creation in Seed


2. 不過在12.1.0.2版本里,oracle引入了參數(shù)EXCLUDE_SEED_CDB_VIEW來控制查看pdb$seed

我們可以看到,默認(rèn)情況下是查詢不到pdb$seed的

SQL> select * from v$version;    

BANNER										     CON_ID
-------------------------------------------------------------------------------- ----------
Oracle Database 12c Enterprise Edition Release 12.1.0.2.0 - 64bit Production		  0
PL/SQL Release 12.1.0.2.0 - Production							  0
CORE	12.1.0.2.0	Production								  0
TNS for Linux: Version 12.1.0.2.0 - Production						  0
NLSRTL Version 12.1.0.2.0 - Production							  0

SQL> select file_name from cdb_data_files;

FILE_NAME
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/dbdata/cdb2/system01.dbf
/u01/dbdata/cdb2/sysaux01.dbf
/u01/dbdata/cdb2/undotbs01.dbf
/u01/dbdata/cdb2/users01.dbf
/u01/dbdata/cdb2/pdb2/system01.dbf
/u01/dbdata/cdb2/pdb2/sysaux01.dbf
/u01/dbdata/cdb2/pdb2/SAMPLE_SCHEMA_users01.dbf
/u01/dbdata/cdb2/pdb2/example01.dbf

8 rows selected.
SQL> SELECT   ksppinm, ksppstvl, ksppdesc   FROM   x$ksppi x, x$ksppcv y  WHERE   x.indx = y.indx AND ksppinm like '%seed_cdb%';

KSPPINM 		       KSPPSTVL 	    KSPPDESC
------------------------------ -------------------- ------------------------------------------------------------
exclude_seed_cdb_view	       TRUE		    exclude PDB$SEED from CDB View Result

 參數(shù)exclude_seed_cdb_view默認(rèn)值為true,當(dāng)設(shè)置為false時,就能查看到pdbs$seed了

SQL> alter system set exclude_seed_cdb_view=FALSE;

System altered.

SQL> select file_name from cdb_data_files;

FILE_NAME
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/dbdata/cdb2/pdb2/system01.dbf
/u01/dbdata/cdb2/pdb2/sysaux01.dbf
/u01/dbdata/cdb2/pdb2/SAMPLE_SCHEMA_users01.dbf
/u01/dbdata/cdb2/pdb2/example01.dbf
/u01/dbdata/cdb2/system01.dbf
/u01/dbdata/cdb2/sysaux01.dbf
/u01/dbdata/cdb2/undotbs01.dbf
/u01/dbdata/cdb2/users01.dbf
/u01/dbdata/cdb2/pdbseed/system01.dbf
/u01/dbdata/cdb2/pdbseed/sysaux01.dbf

10 rows selected.


3. 而在新版本12.2.0.1中,oracle已經(jīng)把 EXCLUDE_SEED_CDB_VIEW作為隱含參數(shù)了,默認(rèn)值同樣為TURE。

SQL> select * from v$version;

BANNER										     CON_ID
-------------------------------------------------------------------------------- ----------
Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production		  0
PL/SQL Release 12.2.0.1.0 - Production							  0
CORE	12.2.0.1.0	Production								  0
TNS for Linux: Version 12.2.0.1.0 - Production						  0
NLSRTL Version 12.2.0.1.0 - Production							  0

SQL> select file_name from cdb_data_files;

FILE_NAME
---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/dbdata/cdb3/system01.dbf
/u01/dbdata/cdb3/sysaux01.dbf
/u01/dbdata/cdb3/undotbs01.dbf
/u01/dbdata/cdb3/users01.dbf
/u01/dbdata/cdb3/orclpdb/system01.dbf
/u01/dbdata/cdb3/orclpdb/sysaux01.dbf
/u01/dbdata/cdb3/orclpdb/undotbs01.dbf
/u01/dbdata/cdb3/orclpdb/users01.dbf

8 rows selected.
SQL> SELECT   ksppinm, ksppstvl, ksppdesc   FROM   x$ksppi x, x$ksppcv y  WHERE   x.indx = y.indx AND ksppinm like '%seed_cdb%';

KSPPINM 		       KSPPSTVL 	    KSPPDESC
------------------------------ -------------------- ------------------------------------------------------------
_exclude_seed_cdb_view	       TRUE		    exclude PDB$SEED from CDB View Result

 不過好在這個參數(shù)可以在instance或session級別修改。

SQL> alter system set "_exclude_seed_cdb_view"=FALSE;

System altered.

SQL> alter session set "_exclude_seed_cdb_view"=FALSE;

Session altered.
SQL> select file_name from cdb_data_files;

FILE_NAME
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
/u01/dbdata/cdb3/system01.dbf
/u01/dbdata/cdb3/sysaux01.dbf
/u01/dbdata/cdb3/undotbs01.dbf
/u01/dbdata/cdb3/users01.dbf
/u01/dbdata/cdb3/orclpdb/system01.dbf
/u01/dbdata/cdb3/orclpdb/sysaux01.dbf
/u01/dbdata/cdb3/orclpdb/undotbs01.dbf
/u01/dbdata/cdb3/orclpdb/users01.dbf
/u01/dbdata/cdb3/pdbseed/system01.dbf
/u01/dbdata/cdb3/pdbseed/sysaux01.dbf
/u01/dbdata/cdb3/pdbseed/undotbs01.dbf

11 rows selected.

   

  從上面的實驗可以看到,oracle越來越重視對pdb$seed的保護。從第一版全部開放,再到12.1.0.2引入普通參數(shù)進行查詢控制,最后干脆改為隱含參數(shù)。

 

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI