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 - The type of object to be retrieved.

-- name - Name of the object.

-- schema - Schema containing the object. Defaults to

-- the caller‘s schema.

-- version - The version of the objects‘ metadata.

-- model - The object model for the metadata.

-- transform. - XSL-T transform. to be applied.

-- RETURNS: Metadata for the object transformed to DDL as a CLOB.

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.得到一个表或索引的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_name)
FROM USER_OBJECTS u
where U.OBJECT_TYPE IN (‘TABLE‘,‘INDEX‘,‘PROCEDURE‘);

3.得到所有表空间的ddl语句

SELECT DBMS_METADATA.GET_DDL(‘TABLESPACE‘, TS.tablespace_name)
FROM DBA_TABLESPACES TS;

4.得到所有创建用户的ddl

SELECT DBMS_METADATA.GET_DDL(‘USER‘,U.username) 
FROM DBA_USERS U;

================================================================================

9i  中可以利用DBMS_METADATA.GET_DDL包得到数据库的对象的ddl脚本。如下(SQLPLUS中执行):

a. 获取单个的建表、视图和建索引的语法

set pagesize 0
set long 90000
set feedback off
set echo off
spool DEPT.sql
select dbms_metadata.get_ddl(‘TABLE‘,‘TAB_NAME‘,‘SCOTT‘) from dual; 
select dbms_metadata.get_ddl(‘VIEW‘,‘VIEW_NAME‘,‘SCOTT‘) from dual; 
select dbms_metadata.get_ddl(‘INDEX‘,‘IDX_NAME‘,‘SCOTT‘) from dual;
spool off;
   
b.获取一个SCHEMA下的所有建表、视图和建索引的语法,以scott为例:
  
set pagesize 0
set long 90000
set feedback off
set echo off
spool schema.sql
connect scott/tiger;
SELECT DBMS_METADATA.GET_DDL(‘TABLE‘,u.table_name) FROM USER_TABLES u;
 SELECT DBMS_METADATA.GET_DDL(‘VIEW‘,u.VIEW_name) FROM USER_VIEWS u;
SELECT DBMS_METADATA.GET_DDL(‘INDEX‘,u.index_name) FROM USER_INDEXES u;
spool off;

c.    获取某个SCHEMA的建全部存储过程的语法
  
set pagesize 0
set long 90000
set feedback off
set echo off
spool procedures.sql  
select   DBMS_METADATA.GET_DDL(‘PROCEDURE‘,u.object_name) from     user_objects u where     object_type = ‘PROCEDURE‘;
spool off;

d.    获取某个SCHEMA的建全部函数的语法
  
set pagesize 0
set long 90000
set feedback off
set echo off
spool function.sql  
select   DBMS_METADATA.GET_DDL(‘FUNCTION‘,u.object_name) from     user_objects u where     object_type = ‘FUNCTION‘;
spool off;

原文地址:https://www.cnblogs.com/jycjy/p/9459134.html

时间: 2024-11-04 18:46:23

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查看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;

dbms_metadata.get_ddl的使用总结

dbms_metadata.get_ddl的使用总结(转载) 在日常工作中,经常有人通过工具去查看对象的定义,其实有时候这样去查看也很烦的.在工作中,也有同事问我怎么获取对象定义,今天我做个总结给大家,希望对大家有所帮助! 获取对象定义的包为:dbms_metadata,其中的get_ddl函数是获取对象的函数 GET_DDL函数返回创建对象的原数据的DDL语句,参数说明 1.object_type ---需要返回原数据的DDL语句的对象类型2.name --- 对象名称3.schema ---

[转] 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('

执行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

Oracle 中deferred_segment_creation 的用法以及exp时解决办法

[email protected]>show parameter segment NAME                                 TYPE        VALUE ------------------------------------ ----------- ------------------------------ deferred_segment_creation            boolean     TRUE rollback_segments