博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通过9i的DBMS_METADATA包得到DLL语句
阅读量:2505 次
发布时间:2019-05-11

本文共 2361 字,大约阅读时间需要 7 分钟。

通过9iDBMS_METADATA包得到DLL语句

 

基本上用到的语法如下:

 

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

set heading off;

set echo off;

set pages 999;

set long 90000;

  

spool dept.sql

select dbms_metadata.get_ddl(table,dept,scott) from dual; 

select dbms_metadata.get_ddl(index,dept_idx,scott) from dual;

spool off;

  

b.获取一个schema下的任何建表和建索引的语法,以scott为例:

 

set pagesize 0

set long 90000

 

set feedback off

 

set echo off 

spool scott_schema.sql 

connect scott/tiger;

select dbms_metadata.get_ddl(table,u.table_name)

      from user_tables u;

select dbms_metadata.get_ddl(index,u.index_name)

      from user_indexes u;

spool off;

  

c.    获取某个schema的建全部存储过程的语法

  connect brucelau /brucelau;

  spool procedures.sql

  select

    dbms_metadata.get_ddl(procedure,u.object_name)

from

    user_objects u

  where

    object_type = procedure;

  spool off;

另: 

dbms_metadata.get_ddl(table,tab1,user1) 

三个参数中,第一个指定导出ddl定义的对象类型(此例中为表类型),第二个是对象名(此例中即表名),第三个是对象所在的用户名。

 

 

Oracle9i开始Oracle提供了一个新的系统包DBMS_METADATA,可以用于提取对象创建的DDL语句。

这个Package功能极其强大,我们来看看它的使用方法.

1.获得表的创建语句.

 

SQL> desc dbms_metadataFUNCTION ADD_TRANSFORM. RETURNS NUMBER...FUNCTION GET_DDL RETURNS CLOB Argument Name Type In/Out Default? ------------------------------ ----------------------- ------ -------- OBJECT_TYPE VARCHAR2 IN NAME VARCHAR2 IN SCHEMA VARCHAR2 IN DEFAULT VERSION VARCHAR2 IN DEFAULT MODEL VARCHAR2 IN DEFAULT TRANSFORM. VARCHAR2 IN DEFAULT....

SQL> set long 2000

SQL> select dbms_metadata.get_ddl('TABLE','TEST') from dual;

 

DBMS_METADATA.GET_DDL('TABLE','TEST')

--------------------------------------------------------------------------------

 

CREATE TABLE "SYS"."TEST"

( "OWNER" VARCHAR2(30),

"OBJECT_NAME" VARCHAR2(128),

"SUBOBJECT_NAME" VARCHAR2(30),

"OBJECT_ID" NUMBER,

"DATA_OBJECT_ID" NUMBER,

"OBJECT_TYPE" VARCHAR2(18),

"CREATED" DATE,

"LAST_DDL_TIME" DATE,

"TIMESTAMP" VARCHAR2(19),

"STATUS" VARCHAR2(7),

"TEMPORARY" VARCHAR2(1),

"GENERATED" VARCHAR2(1),

"SECONDARY" VARCHAR2(1)

) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING

STORAGE(INITIAL 65536 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645

PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)

TABLESPACE "SYSTEM"

 

SQL>

 

 

2.进一步的,可以通过dbms_metadata获得更全面的DDL语句

 

Oracle提供一个全面的范例:

$ORACLE_HOME/rdbms/demo/mddemo.sql

包括索引、授权、触发器等所有DDL语句都可以被提取。

 

有兴趣的可以参考该文件,按照Demo的例子进行测试。

 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/12330444/viewspace-448468/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/12330444/viewspace-448468/

你可能感兴趣的文章
ORA-06512 问题解决
查看>>
hdu 2049 不容易系列之考新郎 && 对错排的详解
查看>>
10个面向程序员的在线编程网站
查看>>
c#设计模式-单例模式(面试题)
查看>>
WPF x名称空间详解
查看>>
pyenv管理多python版本
查看>>
mysql 存储过程和触发器综合例题
查看>>
深度的发现之256个class打平1个id
查看>>
0909我对编译原理的见解
查看>>
lib 和 dll
查看>>
hdu 2042 - 不容易系列之二
查看>>
Linux下设置postgresql数据库开机启动
查看>>
mysql函数技巧整理
查看>>
二叉树
查看>>
IO多路复用--epoll详解
查看>>
[线段树优化应用] 数星星Star
查看>>
表单序列化以及后台表单数据参数的提取
查看>>
SQL语句(十五)视图
查看>>
nginx 设置开机启动
查看>>
继承和组合
查看>>