国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > Oracle > 正文

Oracle中輕松取得建表和索引的DDL語(yǔ)句

2024-08-29 13:50:57
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
我們都知道在9i之前,要想獲得建表和索引的語(yǔ)句是一件很麻煩的事。我們可以通過(guò)eXPort with rows=no來(lái)得到,但它的輸出因?yàn)楦袷降膯?wèn)題并不能直接拿來(lái)用。而另一種方法就是寫(xiě)復(fù)雜的腳本來(lái)查詢數(shù)據(jù)字典,但這對(duì)于一稍微復(fù)雜的對(duì)象,如IOT和嵌套表等,還是無(wú)法查到。 從數(shù)據(jù)字典中獲得DDL語(yǔ)句是經(jīng)常要用的,非凡是在系統(tǒng)升級(jí)/重建的時(shí)候。在Oracle 9i中,我們可以直接通過(guò)執(zhí)行dbms_metadata從數(shù)據(jù)字典中查處DDL語(yǔ)句。使用這個(gè)功能強(qiáng)大的工具,我們可以獲得單個(gè)對(duì)象或整個(gè)SCHEMA的DDL語(yǔ)句。最好不過(guò)的是因?yàn)樗褂闷饋?lái)很簡(jiǎn)單。 1、獲得單個(gè)表和索引DDL語(yǔ)句的方法:
      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;
下面是輸出。我們只要把建表/索引語(yǔ)句取出來(lái)在后面加個(gè)分號(hào)就可以直接運(yùn)行了。
        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、獲得整個(gè)SCHEMA DDL語(yǔ)句的方法:  
    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;
需要注重的是,當(dāng)我們的表中有外健(參照約束)時(shí),我們需要判別參照表之間的順序,確保重建時(shí)按照合理的順序進(jìn)行。你可以通過(guò)查詢dba_constraints and dba_cons_columns來(lái)確定各表之間的順序,不再詳述。


上一篇:Oracle數(shù)據(jù)庫(kù)緩沖區(qū)忙等待的原因解析

下一篇:Oracle中Instance實(shí)例和數(shù)據(jù)庫(kù)的區(qū)別

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
學(xué)習(xí)交流
熱門圖片

新聞熱點(diǎn)

疑難解答

圖片精選

網(wǎng)友關(guān)注

主站蜘蛛池模板: 龙岩市| 衡东县| 铅山县| 平陆县| 房山区| 吉林省| 六盘水市| 德州市| 枞阳县| 醴陵市| 车致| 冀州市| 彭水| 宝坻区| 社会| 夹江县| 绥芬河市| 张北县| 方城县| 清徐县| 元阳县| 郯城县| 容城县| 安达市| 合川市| 酒泉市| 玛曲县| 沙雅县| 通渭县| 富蕴县| 洪洞县| 美姑县| 广东省| 随州市| 稻城县| 西青区| 四会市| 新民市| 当涂县| 泌阳县| 万全县|