dbms_metadata.get_ddl的使用总结
日常工作中,經(jīng)常有人通過工具去查看對象的定義,其實(shí)有時(shí)候這樣去查看也很煩的。在工作中,也有同事問我怎么獲取對象定義,今天我做個(gè)總結(jié)給大家,希望對大家有所幫助!
獲取對象定義的包為:dbms_metadata,其中的get_ddl函數(shù)是獲取對象的函數(shù)
GET_DDL函數(shù)返回創(chuàng)建對象的原數(shù)據(jù)的DDL語句,參數(shù)說明
1、object_type ---需要返回原數(shù)據(jù)的DDL語句的對象類型
2、name --- 對象名稱
3、schema ---對象所在的Schema,默認(rèn)為當(dāng)前用戶所在所Schema
4、version ---對象原數(shù)據(jù)的版本
5、model ---原數(shù)據(jù)的類型默認(rèn)為ORACLE
6、transform. - XSL-T transform. to be applied.
7、RETURNS: 對象的原數(shù)據(jù)默認(rèn)以CLOB類型返回
其中,我們經(jīng)常用到的是前三項(xiàng)。
dbms_metadata包中的get_ddl函數(shù)定義:
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需要進(jìn)行下列格式化,特別需要對long進(jìn)行設(shè)置,否則無法顯示完整的SQL
2、參數(shù)要使用大寫,否則會(huì)查不到
set linesize 180
set pages 999
set long 90000
1、查看數(shù)據(jù)庫表的定義寫法:
select dbms_metadata.get_ddl('TABLE','TABLENAME','USERNAME') from dual;
2、查看索引的SQL
select dbms_metadata.get_ddl('INDEX','INDEXNAME','USERNAME') from dual;
3、查看創(chuàng)建主鍵的SQL
SELECT DBMS_METADATA.GET_DDL('CONSTRAINT','CONSTRAINTNAME','USERNAME') FROM DUAL;
4、查看創(chuàng)建外鍵的SQL
SELECT DBMS_METADATA.GET_DDL('REF_CONSTRAINT','REF_CONSTRAINTNAME','USERNAME') FROM DUAL;
5、查看創(chuàng)建視圖的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、獲取遠(yuǎn)程連接定義SQL
SELECT dbms_metadata.get_ddl('DB_LINK','DBLINKNAME','USERNAME') stmt FROM dual
11、獲取用戶下的觸發(fā)器SQL
select DBMS_METADATA.GET_DDL('TRIGGER','TRIGGERNAME','USERNAME) FROM DUAL;
12、獲取用戶下的序列
select DBMS_METADATA.GET_DDL('SEQUENCE','SEQUENCENAME') from DUAL;
13、獲取用戶下的函數(shù)
select DBMS_METADATA.GET_DDL('FUNCTION','FUNCTIONNAME','USERNAME') from DUAL
14、獲取包的定義
select DBMS_METADATA.GET_DDL('PACKAGE','PACKAGENAME','USERNAME') from dual
15、獲取存儲(chǔ)過程
select DBMS_METADATA.GET_DDL('PROCEDURE','PROCEDURENAME','USERNAME') from dual
16、獲取包體定義
select DBMS_METADATA.GET_DDL('PACKAGE BODY','PACKAGEBODYNAME','USERNAME') from dual
17、獲取遠(yuǎn)程數(shù)據(jù)庫對象的定義
SELECT DBMS_LOB.SUBSTR@dblinkname(DBMS_METADATA.GET_DDL@dblinkname('TABLE', 'TABLENAME', 'USERNAME')) FROM DUAL@dblinkname
18、獲取多個(gè)對象的定義
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';
這個(gè)語句可以更改一下,就可以得到很多語句出來
19、常見錯(cuò)誤
SQL> select dbms_metadata.get_ddl('TABLE','TABLENAME','USERNAME') from dual;
ERROR:
ORA-19206: Invalid value for query or REF CURSOR pa
rameter
ORA-06512: at "SYS.DBMS_XMLGEN", line 83
ORA-06512: at "SYS.DBMS_METADATA", line 345
ORA-06512: at "SYS.DBMS_METADATA", line 410
ORA-06512: at "SYS.DBMS_METADATA", line 449
ORA-06512: at "SYS.DBMS_METADATA", line 615
ORA-06512: at "SYS.DBMS_METADATA", line 1221
ORA-06512: at line 1
no rows selected
解決辦法:運(yùn)行 $ORACLE_HOME/rdbms/admin/catmeta.sql
? ? ?本文轉(zhuǎn)自whshurk 51CTO博客,原文鏈接:http://blog.51cto.com/shurk/2057030,如需轉(zhuǎn)載請自行聯(lián)系原作者
總結(jié)
以上是生活随笔為你收集整理的dbms_metadata.get_ddl的使用总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 奔腾互联app(奔腾&174)
- 下一篇: [IE技巧] 让IE 以全屏模式启动