IT貓撲網(wǎng):您身邊最放心的安全下載站! 最新更新|軟件分類|軟件專題|手機版|論壇轉貼|軟件發(fā)布

您當前所在位置: 首頁數(shù)據(jù)庫Oracle → 如何提高ORACLE數(shù)據(jù)庫的查詢統(tǒng)計速度

如何提高ORACLE數(shù)據(jù)庫的查詢統(tǒng)計速度

時間: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?  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ù)庫

相關閱讀

文章評論
發(fā)表評論

熱門文章 Oracle中使用alter table來增加,刪除,修改列的語法 Oracle中使用alter table來增加,刪除,修改列的語法 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 誤刪Oracle數(shù)據(jù)庫實例的控制文件 誤刪Oracle數(shù)據(jù)庫實例的控制文件 為UNIX服務器設置Oracle全文檢索 為UNIX服務器設置Oracle全文檢索

相關下載

    人氣排行 oracle中使用SQL語句修改字段類型-oracle修改SQL語句案例 Oracle中使用alter table來增加,刪除,修改列的語法 ORACLE SQL 判斷字符串是否為數(shù)字的語句 ORACLE和SQL語法區(qū)別歸納(1) oracle grant 授權語句 ORACLE修改IP地址后如何能夠使用 如何加速Oracle大批量數(shù)據(jù)處理 Oracle刪除表的幾種方法