提高ORACLE資料庫的查詢統計速度

來源:互聯網
上載者:User
oracle|資料|資料庫|速度|統計
大型資料庫系統中往往要用到查詢統計,但是對於資料量大的系統,使用者在進行複雜的查詢統計時往往感到速度很慢,不能滿足應用要求,這就要求我們在設計資料庫系統時進行合理設定,提高查詢統計的速度。本文結合筆者的項目開發經驗,闡述具體的設定方法。 以oracle7.33資料庫系統為例,我們在開發大型oracle資料庫系統時結合項目的特點,本著安全、高效的原則對資料庫進行了一些實體設計,從而大大提高了資料庫的查詢統計速度。總結為如下幾點:   1)擴大資料資料表空間到500M,用於存放本系統的資料;      2)段盤區的初始大小為10K,增長大小為10K,增長幅度為1;      3)使用者臨時空間增大40M;      4)系統暫存資料表空間和復原段資料表空間增大40M,並且建立4個復原段;      5)需要經常連接查詢,而且資料量又大的庫存表、名錄表、收發料表放在一簇內;      6)提供定時備份,備份檔案放在另外的機器上。      設定資料資料表空間的SQL語句如下:      CREATE TABLESPACE WXGL_DATA1 DATAFILE 'WXGL_DATA1.ORA' SIZE 500M ONLINE;        增加系統暫存資料表空間和復原段資料表空間的SQL語句如下:      ALTER TABLESPACE TEMPORARY_DATA ADD DATAFILE 'TMP2ORCL.ORA' SIZE 40M;   ALTER TABLESPACE ROLLBACK_DATA ADD DATAFILE 'RBS2ORCL.ORA' SIZE 40M;        將資料空間設定在指定的資料檔案的SQL語句如下:      CREATE USER ZBGL IDENTIFIED BY ZBGL;   GRANT DBA TO ZBGL;   ALTER USER ZBGL DEFAULT TABLESPACE WXGL_DATA1 TEMPORARY TABLESPACE TEMPORARY_DATA;
1. 設定五個復原段的SQL語句如下:    SELECT SEGMENT_NAME FROM DBA_ROLLBACK_SEGS WHERE INITIAL_EXTENT < 512000 AND   UPPPER(OWNER) = 'PUBLIC';   SELECT UPPER(STATUS) FROM DBA_ROLLBACK_SEGS WHERE UPPER(SEGMENT_NAME) = ''      ALTER ROLLBACK SEGMENT RB1 OFFLINE;   ALTER ROLLBACK SEGMENT RB2 OFFLINE;   ALTER ROLLBACK SEGMENT RB3 OFFLINE;   ALTER ROLLBACK SEGMENT RB4 OFFLINE;   ALTER ROLLBACK SEGMENT RB5 OFFLINE;      DROP ROLLBACK SEGMENT RB1;   DROP ROLLBACK SEGMENT RB2;   DROP ROLLBACK SEGMENT RB3;   DROP ROLLBACK SEGMENT RB4;   DROP ROLLBACK SEGMENT RB5;      CREATE PUBLIC ROLLBACK SEGMENT RB1 TABLESPACE ROLLBACK_DATA    STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);   CREATE PUBLIC ROLLBACK SEGMENT RB2 TABLESPACE ROLLBACK_DATA    STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);   CREATE PUBLIC ROLLBACK SEGMENT RB3 TABLESPACE ROLLBACK_DATA    STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);   CREATE PUBLIC ROLLBACK SEGMENT RB4 TABLESPACE ROLLBACK_DATA    STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);   CREATE PUBLIC ROLLBACK SEGMENT RB5 TABLESPACE ROLLBACK_DATA    STORAGE (INITIAL 512000 NEXT 512000 MAXEXTENTS 121);      ALTER ROLLBACK SEGMENT RB1 ONLINE;   ALTER ROLLBACK SEGMENT RB2 ONLINE;   ALTER ROLLBACK SEGMENT RB3 ONLINE;   ALTER ROLLBACK SEGMENT RB4 ONLINE;   ALTER ROLLBACK SEGMENT RB5 ONLINE;      COMMIT; 2.將資料量大的庫存表等放在一簇內的SQL語句如下:       KCB='CREATE TABLE QC_KCB( '    +' CKNM NUMBER(8) ,'    +' QCNM NUMBER(10) ,'    +' CKKC NUMBER(12,2),'    +' SNCKKC NUMBER(12,2),'    +' LDJ NUMBER(12,2),'    +' BZ VARCHAR(100),'    +' PRIMARY KEY(CKNM,QCNM))'    +' TABLESPACE WXGL_DATA1 ' ;(大資料量的庫存表等放在WXGL_DATA1)   QCFL = 'CREATE TABLE QC_QCFL '    + '(FLBH NUMBER(2) PRIMARY KEY,'    + ' FLMC VARCHAR(20) '    + ' ) '    +' TABLESPACE WXGL_DATA2 ' ;(其他表放在WXGL_DATA2)

相關文章

Cloud Intelligence Leading the Digital Future

Alibaba Cloud ACtivate Online Conference, Nov. 20th & 21st, 2019 (UTC+08)

Register Now >

Starter Package

SSD Cloud server and data transfer for only $2.50 a month

Get Started >

Alibaba Cloud Free Trial

Learn and experience the power of Alibaba Cloud with a free trial worth $300-1200 USD

Learn more >

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。