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

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

Oracle 9i輕松取得建表和索引DDL語句

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


上一篇:Oracle使用ANYDATA列對數(shù)據(jù)串行化方法

下一篇:Oracle內(nèi)部工具Block Corruption介紹

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

新聞熱點(diǎn)

疑難解答

圖片精選

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

主站蜘蛛池模板: 久在线 | 九九av | 午夜窝窝 | 国产精品大全 | 成人午夜毛片 | 在线免费观看黄 | 久久精品国产免费看久久精品 | 精品国产高清一区二区三区 | 久久se精品一区精品二区 | 欧美日一区二区 | 人人草人人干 | 日日摸天天做天天添天天欢 | 日韩一区二区三区四区五区 | 黄色日批视频 | 亚洲电影中文字幕 | 91精品专区 | 国产日韩欧美一区二区 | 亚洲视频中文字幕 | 日韩精品免费一区二区夜夜嗨 | 国产一国产寡妇一级毛片 | 国产在线2 | 成全视频免费观看在线看黑人 | 中文字幕一区二区三区乱码图片 | 欧美日韩精品一区二区三区在线观看 | 青青久久| 日韩视频在线观看不卡 | 日韩在线三级 | 一区免费在线观看 | 亚洲精品一区二区三区在线看 | 国产ts余喵喵和直男多体位 | 91精品国产综合久久久久久软件 | 手机看片169 | a在线看| 一区二区在线免费观看 | 在线免费精品 | 久久精品视频网址 | 欧美在线| 午夜欧美 | 综合一区二区三区 | 欧美日本国产 | 午夜久久久久 |