中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

dbms_metadata.get_ddl的使用總結

發布時間:2020-04-02 00:47:41 來源:網絡 閱讀:2211 作者:whshurk 欄目:關系型數據庫

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

獲取對象定義的包為: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 180
set pages 999
set long 90000

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';

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

19、常見錯誤
SQL> select dbms_metadata.get_ddl('TABLE','TABLENAME','USERNAME') from dual;
ERROR:
ORA-19206: Invalid value for query or REF CURSOR parameter
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
解決辦法:運行 $ORACLE_HOME/rdbms/admin/catmeta.sql

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岑溪市| 贞丰县| 苏尼特右旗| 东兴市| 吉林市| 偏关县| 德化县| 昌邑市| 崇义县| 长岛县| 梅州市| 广东省| 广饶县| 辽阳县| 大宁县| 蓬安县| 临沭县| 大城县| 大渡口区| 滕州市| 林西县| 库车县| 柳州市| 锦州市| 贡嘎县| 绥棱县| 柘城县| 博乐市| 饶阳县| 绩溪县| 宜黄县| 三门峡市| 云阳县| 哈巴河县| 车致| 沙雅县| 和硕县| 曲松县| 巫山县| 汉寿县| 肇州县|