時間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評論(0)
大型數(shù)據(jù)庫系統(tǒng)中往往要用到查詢統(tǒng)計,但是對于數(shù)據(jù)量大的系統(tǒng),用戶在進行復雜的查詢統(tǒng)計時往往感到速度很慢,不能滿足應用要求,這就要求我們在設計數(shù)據(jù)庫系統(tǒng)時進行合理設置,提高查詢統(tǒng)計的速度。本文結合筆者的項目開發(fā)經(jīng)驗,闡述具體的設置方法。
以oracle7.33數(shù)據(jù)庫系統(tǒng)為例,我們在開發(fā)大型oracle數(shù)據(jù)庫系統(tǒng)時結合項目的特點,本著安全、高效的原則對數(shù)據(jù)庫進行了一些物理設計,從而大大提高了數(shù)據(jù)庫的查詢統(tǒng)計速度??偨Y為如下幾點:
1)擴大數(shù)據(jù)表空間到500M,用于存放本系統(tǒng)的數(shù)據(jù);
2)段盤區(qū)的初始大小為10K,增長大小為10K,增長幅度為1;
3)用戶臨時空間增大40M;
4)系統(tǒng)臨時表空間和回滾段表空間增大40M,并且新建4個回滾段;
5)需要經(jīng)常聯(lián)結查詢,而且數(shù)據(jù)量又大的庫存表、名錄表、收發(fā)料表放在一簇內(nèi);
6)提供定時備份,備份文件放在另外的機器上。
設置數(shù)據(jù)表空間的SQL語句如下:
CREATE?TABLESPACE?WXGL_DATA1?DATAFILE?'WXGL_DATA1.ORA'?SIZE?500M?ONLINE; |
增加系統(tǒng)臨時表空間和回滾段表空間的SQL語句如下:
ALTER?TABLESPACE?TEMPORARY_DATA?ADD?DATAFILE?'TMP2ORCL.ORA'?SIZE?40M; ALTER?TABLESPACE?ROLLBACK_DATA?ADD?DATAFILE?'RBS2ORCL.ORA'?SIZE?40M; |
將數(shù)據(jù)空間設置在指定的數(shù)據(jù)文件的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.將數(shù)據(jù)量大的庫存表等放在一簇內(nèi)的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?'?;(大數(shù)據(jù)量的庫存表等放在WXGL_DATA1) QCFL?=?'CREATE?TABLE?QC_QCFL?' +?'(FLBH?NUMBER(2)?PRIMARY?KEY,' +?'?FLMC?VARCHAR(20)?' +?'?)?' +'?TABLESPACE?WXGL_DATA2?'?;(其他表放在WXGL_DATA2 |
關鍵詞標簽:ORACLE數(shù)據(jù)庫
相關閱讀
熱門文章 Oracle中使用alter table來增加,刪除,修改列的語法 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 誤刪Oracle數(shù)據(jù)庫實例的控制文件 為UNIX服務器設置Oracle全文檢索
人氣排行 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 Oracle中使用alter table來增加,刪除,修改列的語法 ORACLE SQL 判斷字符串是否為數(shù)字的語句 ORACLE和SQL語法區(qū)別歸納(1) oracle grant 授權語句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法