a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > Oracle > 正文

Oracle中輕松取得建表和索引的DDL語句

2024-08-29 13:50:57
字體:
來源:轉載
供稿:網友
我們都知道在9i之前,要想獲得建表和索引的語句是一件很麻煩的事。我們可以通過eXPort with rows=no來得到,但它的輸出因為格式的問題并不能直接拿來用。而另一種方法就是寫復雜的腳本來查詢數據字典,但這對于一稍微復雜的對象,如IOT和嵌套表等,還是無法查到。 從數據字典中獲得DDL語句是經常要用的,非凡是在系統升級/重建的時候。在Oracle 9i中,我們可以直接通過執行dbms_metadata從數據字典中查處DDL語句。使用這個功能強大的工具,我們可以獲得單個對象或整個SCHEMA的DDL語句。最好不過的是因為它使用起來很簡單。 1、獲得單個表和索引DDL語句的方法:
      set heading off;    set echo off;    Set pages 999;    set long 90000;         spool get_single.sql    select dbms_metadata.get_ddl('TABLE','SZT_PQSO2','SHQSYS') from dual;    select dbms_metadata.get_ddl('INDEX','INDXX_PQZJYW','SHQSYS') from dual;    spool off;
下面是輸出。我們只要把建表/索引語句取出來在后面加個分號就可以直接運行了。
        SQL> select dbms_metadata.get_ddl('TABLE','SZT_PQSO2','SHQSYS') from dual;         CREATE TABLE "SHQSYS"."SZT_PQSO2"     ( "PQBH" VARCHAR2(32) NOT NULL ENABLE,     "ZJYW" NUMBER(10,0),     "CGSO" NUMBER(10,0) NOT NULL ENABLE,     "SOLS" VARCHAR2(17),     "SORQ" VARCHAR2(8),     "SOWR" VARCHAR2(8),     "SOCL" VARCHAR2(6),     "YWHM" VARCHAR2(10),     "YWLX" VARCHAR2(6)     ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255 NOCOMPRESS LOGGING     STORAGE(INITIAL 1048576 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645     PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)     TABLESPACE "DATA1"       SQL> select dbms_metadata.get_ddl ('INDEX','INDXX_PQZJYW','SHQSYS') from dual;    CREATE INDEX "SHQSYS"."INDXX_PQZJYW" ON "SHQSYS"."SZT_PQSO2" ("ZJYW")     PCTFREE 10 INITRANS 2 MAXTRANS 255     STORAGE(INITIAL 1048576 NEXT 1048576 MINEXTENTS 1 MAXEXTENTS 2147483645     PCTINCREASE 0 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT)     TABLESPACE "DATA1"     SQL>     SQL> spool off;
2、獲得整個SCHEMA DDL語句的方法:  
    set pagesize 0    set long 90000    set feedback off    set echo off     spool get_schema.sql     connect shqsys/shqsys@hawk1;    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;
需要注重的是,當我們的表中有外健(參照約束)時,我們需要判別參照表之間的順序,確保重建時按照合理的順序進行。你可以通過查詢dba_constraints and dba_cons_columns來確定各表之間的順序,不再詳述。


上一篇:Oracle數據庫緩沖區忙等待的原因解析

下一篇:Oracle中Instance實例和數據庫的區別

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
學習交流
熱門圖片

新聞熱點

疑難解答

圖片精選

網友關注

主站蜘蛛池模板: av网站在线免费观看 | 久久精品日产高清版的功能介绍 | 国产精品片aa在线观看 | 国产大片中文字幕在线观看 | 91在线精品一区二区 | 午夜寂寞影视 | 国产成人一区二区三区 | 日本高清久久 | 精品九九| 日韩在线看片 | a级在线免费观看 | 日韩在线一区二区 | 一级片在线观看免费 | 日本不卡免费新一二三区 | 日本一区二区在线视频 | www.久久久| 国产欧美日韩精品一区 | 久久机热| 国产亚洲精品精品国产亚洲综合 | 欧美中文在线 | 亚洲视频在线看 | 色黄网站 | 久久久久国产一区二区三区四区 | 一级全黄少妇性色生活片毛片 | 国产成人精品免费 | 久久国产精品一区二区 | 特级淫片裸体免费看 | 一区二区三区高清 | aaaa网站| 精品一二区 | 午夜视频在线观看网站 | 欧美一区二区三区精品 | 一级黄色在线 | 四虎黄色网| 区一区二免费视频 | 欧美精品一区二区三区一线天视频 | 国产欧美精品一区二区三区四区 | 国产精品视频久久久久久 | 日本妇人成熟免费视频 | 国产精品一区二区日韩新区 | 亚洲国产精品久久久久秋霞不卡 |