oracle獲取資料字典定義詳細總結

datapeng發表於2013-12-08



在日常工作中,經常有人透過工具去檢視物件的定義,其實有時候這樣去檢視也很煩的。在工作中,也有同事問我怎麼獲取物件定義,今天我做個總結給大家,希望對大家有所幫助! 

獲取物件定義的包為:dbms_metadata,其中的get_ddl函式是獲取物件的函式 

GET_DDL函式返回建立物件的原資料的DDL語句,引數說明 

1、object_type ---需要返回原資料的DDL語句的物件型別 
2、name --- 物件名稱 
3、schema ---物件所在的Schema,預設為當前使用者所在所Schema 
4、version ---物件原資料的版本 
5、model ---原資料的型別預設為ORACLE 
6、transform. - XSL-T transform. to be applied. 
7、RETURNS: 物件的原資料預設以CLOB型別返回 

其中,我們經常用到的是前三項。 

dbms_metadata包中的get_ddl函式定義: 

FUNCTION get_ddl ( object_type IN VARCHAR2, 
name IN VARCHAR2, 
schema IN VARCHAR2 DEFAULT NULL, 
version IN VARCHAR2 DEFAULT 'COMPATIBLE', 
model IN VARCHAR2 DEFAULT 'ORACLE', 
transform. IN VARCHAR2 DEFAULT 'DDL') RETURN CLOB; 

注意: 

1、如果使用sqlplus需要進行下列格式化,特別需要對long進行設定,否則無法顯示完整的SQL 
2、引數要使用大寫,否則會查不到 

set linesize 400     
set pages 0 
set long 10000

1、檢視資料庫表的定義寫法: 

select dbms_metadata.get_ddl('TABLE','TABLENAME','USERNAME') from dual;  

2、檢視索引的SQL 

select dbms_metadata.get_ddl('INDEX','INDEXNAME','USERNAME') from dual; 

3、檢視建立主鍵的SQL 

SELECT DBMS_METADATA.GET_DDL('CONSTRAINT','CONSTRAINTNAME','USERNAME') FROM DUAL;  

4、檢視建立外來鍵的SQL 

SELECT DBMS_METADATA.GET_DDL('REF_CONSTRAINT','REF_CONSTRAINTNAME','USERNAME') FROM DUAL;  

5、檢視建立檢視的SQL 

SELECT DBMS_METADATA.GET_DDL('VIEW','VIEWNAME','USERNAME') FROM DUAL; 

6、檢視使用者的SQL 

SELECT DBMS_METADATA.GET_DDL('USER','USERNAME') FROM DUAL; 

7、檢視角色的SQL 

SELECT DBMS_METADATA.GET_DDL('ROLE','ROLENAME') FROM DUAL; 

8、檢視錶空間的SQL 

SELECT DBMS_METADATA.GET_DDL('TABLESPACE','TABLESPACENAME') FROM DUAL; 

9、獲取物化檢視SQL 

select dbms_metadata.get_ddl('MATERIALIZED VIEW','MVNAME') FROM DUAL; 

10、獲取遠端連線定義SQL 

SELECT dbms_metadata.get_ddl('DB_LINK','DBLINKNAME','USERNAME') stmt FROM dual 

11、獲取使用者下的觸發器SQL 

select DBMS_METADATA.GET_DDL('TRIGGER','TRIGGERNAME','USERNAME) FROM DUAL; 

12、獲取使用者下的序列 

select DBMS_METADATA.GET_DDL('SEQUENCE','SEQUENCENAME') from  DUAL; 

13、獲取使用者下的函式 

select DBMS_METADATA.GET_DDL('FUNCTION','FUNCTIONNAME','USERNAME') from DUAL 

14、獲取包的定義 

select DBMS_METADATA.GET_DDL('PACKAGE','PACKAGENAME','USERNAME') from  dual 

15、獲取儲存過程 

select DBMS_METADATA.GET_DDL('PROCEDURE','PROCEDURENAME','USERNAME') from  dual 

16、獲取包體定義 

select DBMS_METADATA.GET_DDL('PACKAGE BODY','PACKAGEBODYNAME','USERNAME') from  dual 

17、獲取遠端資料庫物件的定義 

SELECT DBMS_LOB.SUBSTR@dblinkname(DBMS_METADATA.GET_DDL@dblinkname('TABLE', 'TABLENAME', 'USERNAME')) FROM DUAL@dblinkname 

18、獲取多個物件的定義 

SELECT DBMS_METADATA.GET_DDL(O.OBJECT_TYPE, O.object_name,O.OWNER) 
FROM DBA_OBJECTS O 
where O.OBJECT_TYPE IN ('TABLE','INDEX','PROCEDURE','FUNCTION') and ONWER = 'ONWERNAME';  

這個語句可以更改一下,就可以得到很多語句出來

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29371470/viewspace-1062703/,如需轉載,請註明出處,否則將追究法律責任。

相關文章