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

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

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

2024-08-29 13:46:27
字體:
供稿:網(wǎng)友
我們都知道在9i之前,要想獲得建表和索引的語(yǔ)句是一件很麻煩的事。我們通常的做法都是通過eXPort with rows=no來得到,但它的輸出因?yàn)楦袷降膯栴}并不能直接拿來用。而另一種方法就是寫復(fù)雜的腳本來查詢數(shù)據(jù)字典,但這對(duì)于一稍微復(fù)雜的對(duì)象,如IOT和嵌套表等,還是無法查到。

  從數(shù)據(jù)字典中獲得DDL語(yǔ)句是經(jīng)常要用的,非凡是在系統(tǒng)升級(jí)/重建的時(shí)候。在Oracle 9i中,我們可以直接通過執(zhí)行dbms_metadata從數(shù)據(jù)字典中查處DDL語(yǔ)句。使用這個(gè)功能強(qiáng)大的工具,我們可以獲得單個(gè)對(duì)象或整個(gè)SCHEMA的DDL語(yǔ)句。最好不過的是因?yàn)樗褂闷饋砗芎?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ǔ)句取出來在后面加個(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)行。你可以通過查詢dba_constraints and dba_cons_columns來確定各表之間的順序,不再詳述。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 无锡市| 分宜县| 鄂伦春自治旗| 锦屏县| 锡林浩特市| 墨江| 南和县| 涟源市| 井冈山市| 大安市| 民和| 罗平县| 和静县| 葫芦岛市| 巴中市| 灵宝市| 九寨沟县| 高清| 武强县| 包头市| 吉安市| 襄城县| 文水县| 南开区| 大名县| 开远市| 白河县| 道孚县| 当雄县| 二连浩特市| 屏东市| 咸阳市| 长岭县| 荣成市| 杂多县| 黎城县| 武山县| 博湖县| 商丘市| 尚义县| 佛山市|