程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> 關於Oracle數據庫 >> 通過Oracle 9i的DBMS_METADATA包得到DLL語句

通過Oracle 9i的DBMS_METADATA包得到DLL語句

編輯:關於Oracle數據庫

  通過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的例子進行測試。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved