dbms_metadata.get_ddl的使用总结

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

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

获取对象定义的包为: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 [email protected]([email protected](‘TABLE‘, ‘TABLENAME‘, ‘USERNAME‘)) FROM [email protected]

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

dbms_metadata.get_ddl的使用总结,布布扣,bubuko.com

时间: 2024-08-13 18:49:29

dbms_metadata.get_ddl的使用总结的相关文章

利用dbms_metadata.get_ddl查看DDL语句

当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metadata.get_ddl这个包来查看. dbms_metadata包中的get_ddl函数详细参数GET_DDL函数返回创建对象的原数据的DDL语句,详细参数如下-- object_type ---需要返回原数据的DDL语句的对象类型-- name --- 对象名称-- schema ---对象所在的Schema,默认为当前用户所在所Schema-- version ---对象原数据的版本-- model ---原数据的类

Oracle利用dbms_metadata.get_ddl查看DDL语句

当我们想要查看某个表或者是表空间的DDL的时候,可以利用dbms_metadata.get_ddl这个包来查看. dbms_metadata包中的get_ddl函数详细参数 GET_DDL函数返回创建对象的原数据的DDL语句,详细参数如下 -- object_type ---需要返回原数据的DDL语句的对象类型 -- name --- 对象名称 -- schema ---对象所在的Schema,默认为当前用户所在所Schema -- version ---对象原数据的版本 -- model --

Oracle DBMS_METADATA.GET_DDL

查看表结构的详细信息 create table tset(id number,names varchar2(20)); SELECT DBMS_METADATA.GET_DDL('TABLE','TSET')  FROM DUAL;

[转] Oracle利用DBMS_METADATA.GET_DDL获取对象DDL语句

dbms_metadata.get_ddl 1.得到一个表或索引的ddl语句SELECT DBMS_METADATA.GET_DDL('TABLE','DEPT','SCOTT') FROM DUAL; select dbms_metadata.get_ddl('INDEX','PK_DEPT','SCOTT') from dual; 2.得到一个用户下的所有表,索引,存储过程的ddl SELECT DBMS_METADATA.GET_DDL(U.OBJECT_TYPE, u.object_na

SQL_使用DBMS_METADATA.GET_DDL生成建表语句

原创作品,出自 "深蓝的blog" 博客,欢迎转载,转载时请务必注明以下出处,否则追究版权法律责任. 深蓝的blog:http://blog.csdn.net/huangyanlong/article/details/43988377 今天在群里学来一着,通过DBMS_METADATA.GET_DDL来生成建表或视图的sql语句. (1).生成创建表的sql语句 SQL> set long 20000; SQL> SELECT DBMS_METADATA.GET_DDL('

【转载】oracle dbms_metadata.get_ddl的使用方法总结

转自:http://www.jb51.net/article/39715.htm dbms_metadata.get_ddl()用于获取对象的ddl,其具体用法如下. 注意:在sqlplus里,为了更好的展示DDL,需要设置如下参数: set line 200set pagesize 0set long 99999set feedback offset echo off 1)获得表.索引.视图.存储过程.函数的DDL 代码如下: select dbms_metadata.get_ddl('TAB

执行DBMS_METADATA.get_ddl报ORA-39212的解决方法

环境:    数据库:oracle 10.2.0.4 --64位    操作系统:红旗dc 5.0  --64位 以sys登陆,执行DBMS_METADATA.get_ddl得到某个表空间的元数据报错select DBMS_METADATA.get_ddl('TABLESPACE','PDA') from dual;ERROR:ORA-39212: installation error: XSL stylesheets not loaded correctlyORA-06512: at "SYS

dbms_metadata.get_ddl的用法

dbms_metadata包中的get_ddl函数 --GET_DDL: Return the metadata for a single object as DDL. -- This interface is meant for casual browsing (e.g., from SQLPlus) -- vs. the programmatic OPEN / FETCH / CLOSE interfaces above. -- PARAMETERS: -- object_type - Th

DBMS_METADATA中使用SESSION_TRANSFORM过滤不想获取的DDL

我们一般使用dbms_metadata.get_ddl获取对象的ddl的时候,有时会获取一些其他额外的信息,例如当你想获取表的创建语句的时候,你会得到表的约束信息,这个信息可能是你不想要的,那么就可以用SESSION_TRANSFORM对它进行过滤. 看下面的示例,创建一个有主键和外键的表,获取他的ddl语句: SQL> CREATE TABLE tb1 (id int primary key); Table created. SQL> create table tb2 (id int pri