oracle get_dll job,通过Oracle 9i的DBMS_METADATA包得到DLL语句 可以用于提取对象创建的DDL语句...

通过Oracle 9i的DBMS_METADATA包得到DLL语句

基本上用到的语法如下:

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

setheadingoff;

setechooff;

setpages999;

setlong90000;

spooldept.sql

selectdbms_metadata.get_ddl(table,dept,scott)fromdual;

selectdbms_metadata.get_ddl(index,dept_idx,scott)fromdual;

spooloff;

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

setpagesize0

setlong90000

setfeedbackoff

setechooff

spoolscott_schema.sql

connectscott/tiger;

selectdbms_metadata.get_ddl(table,u.table_name)

fromuser_tablesu;

selectdbms_metadata.get_ddl(index,u.index_name)

fromuser_indexesu;

spooloff;

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

connectbrucelau/brucelau;

spoolprocedures.sql

select

dbms_metadata.get_ddl(procedure,u.object_name)

from

user_objectsu

where

object_type=procedure;

spooloff;

另:

dbms_metadata.get_ddl(table,tab1,user1)

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

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

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

1.获得表的创建语句.

SQL>descdbms_metadataFUNCTIONADD_TRANSFORM.RETURNSNUMBER...FUNCTIONGET_DDLRETURNSCLOBArgumentNameTypeIn/OutDefault?

OBJECT_TYPEVARCHAR2INNAMEVARCHAR2INSCHEMAVARCHAR2INDEFAULTVERSIONVARCHAR2INDEFAULTMODELVARCHAR2INDEFAULTTRANSFORM.VARCHAR2INDEFAULT....

SQL>setlong2000

SQL>selectdbms_metadata.get_ddl('TABLE','TEST')fromdual;

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

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

CREATETABLE"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)

)PCTFREE10PCTUSED40INITRANS1MAXTRANS255NOCOMPRESSLOGGING

STORAGE(INITIAL65536NEXT1048576MINEXTENTS1MAXEXTENTS2147483645

PCTINCREASE0FREELISTS1FREELISTGROUPS1BUFFER_POOLDEFAULT)

TABLESPACE"SYSTEM"

SQL>

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

Oracle提供一个全面的范例:

$ORACLE_HOME/rdbms/demo/mddemo.sql

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

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值