dbms_metadata.get_ddl的使用总结(转载) jdbc getmetadata

在日常工作中,经常有人通过工具去查看对象的定义,其实有时候这样去查看也很烦的。在工作中,也有同事问我怎么获取对象定义,今天我做个总结给大家,希望对大家有所帮助!

获取对象定义的包为: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,
dbms_metadata.get_ddl的使用总结(转载) jdbc getmetadata
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') fromdual;

2、查看索引的SQL

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

3、查看创建主键的SQL

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

4、查看创建外键的SQL

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

5、查看创建视图的SQL

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

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

9、获取物化视图SQL

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

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

13、获取用户下的函数

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

14、获取包的定义

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

15、获取存储过程

selectDBMS_METADATA.GET_DDL('PROCEDURE','PROCEDURENAME','USERNAME') fromdual

16、获取包体定义

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

17、获取远程数据库对象的定义

SELECTDBMS_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') andONWER = 'ONWERNAME';

这个语句可以更改一下,就可以得到很多语句出来

19、常见错误
SQL> selectdbms_metadata.get_ddl('TABLE','TABLENAME','USERNAME') fromdual;
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

  

爱华网本文地址 » http://www.413yy.cn/a/25101011/51775.html

更多阅读

转载 深层清洁面膜的使用方法指南 深层清洁面膜排行榜

原文地址:深层清洁面膜的使用方法指南作者:女人面膜资讯什么是深层清洁面膜?顾名思义,是一种能够深入清洁皮肤毛孔内部的污垢和过剩油脂的洁肤型面膜,相对于洁面乳,它的清洁能力更深入更彻底。一、深层清洁的意义我们的皮肤也会呼吸,它会

转载 十二种色彩季型的大致总结 十二种色彩

原文地址:十二种色彩季型的大致总结作者:风依伊肤色的黑白不能决定你的色彩季型,再也不要说”皮肤白穿什么好看皮肤黑穿什么好看”的话.眼白呈淡蓝色的很有可能属于春季型和冬季型这六种季型.

原创 IE80之耳套使用总结 微信原创申明如何使用

入了IE80一个月了,感觉不写个耳套使用总结太对不起人了。写的不好请详细指出,写的好请点个赞Or留个言,不晓得我在说什么的请自动在此日志评论“不明觉厉”,谢谢合作。以下全文为使用者代某亲自写出的听感,严禁转载。如图:第一排:类海绵

转载 183.几位同学的期末总结1 ——吕珊珊 yy小魔女吕珊珊

翻译是个终生的学习过程,如同做人。我非常佩服栓哥和周老师能够在自己的领域中做到具有无可替代性,也很佩服他们在课上精辟的论述。我也亲眼目睹了他们为之付出的辛劳,深知“台上一分钟,台下十年功”的道理。我很庆幸能够遇到如此负责、

声明:《dbms_metadata.get_ddl的使用总结(转载) jdbc getmetadata》为网友单身万岁分享!如侵犯到您的合法权益请联系我们删除