eygle.com   eygle.com
eygle.com  
 

« Oracle整合仁科的困难 | Blog首页 | 颇为搞笑的--人大mm在水木清华上的征婚与回复 »

Oracle9i新特性-使用DBMS_METADATA包获得对象DDL语句

作者:eygle |【转载时请以超链接形式标明文章和作者信息及本声明
链接:

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

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

1.获得表的创建语句.

SQL> desc dbms_metadata
FUNCTION 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的例子进行测试。


历史上的今天...
      >> 2008-12-22文章:
      >> 2007-12-22文章:
             Baby病愈及装修阶段性竣工
      >> 2006-12-22文章:
      >> 2005-12-22文章:
------
这篇 【Oracle9i新特性-使用DBMS_METADATA包获得对象DDL语句】来自 eygle.com | CSDN网摘| del.icio.us|Google订阅 | 鲜果订阅 | 抓虾订阅

By eygle on 2004-12-22 14:35 | Comments (0) | Posted to FAQ | Edit |

相关文章 随机文章
  • dbms_system.ksdwrt:向告警日志文件写指定信息
  • 10g临时表空间组导致递归SQL高度解析案例
  • Oracle的SQL可以有多长?
  • xmldom.setCharset无效问题的解决
  • 使用Catalog命令注册RMAN备份集
  • Linux RAC OCFS文件系统与INODES
    LGWR与AIX上的进程优先级
    Install MT WYSIWYG plugin FCKeditor
    "中国软件技术大会"和朋友们在一起
    装修日记:安信地板之无商不奸篇
    搜索本站:

    留言 (0)

    发表留言:



    Remember Me?
    (输入验证码后方可评论,谢谢支持)



    CopyRight © 2004~2010 eygle.com, All rights reserved.