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

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

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

時(shí)間:2015-06-28 00:00:00 來源:IT貓撲網(wǎng) 作者:網(wǎng)管聯(lián)盟 我要評(píng)論(0)

  大型數(shù)據(jù)庫(kù)系統(tǒng)中往往要用到查詢統(tǒng)計(jì),但是對(duì)于數(shù)據(jù)量大的系統(tǒng),用戶在進(jìn)行復(fù)雜的查詢統(tǒng)計(jì)時(shí)往往感到速度很慢,不能滿足應(yīng)用要求,這就要求我們?cè)谠O(shè)計(jì)數(shù)據(jù)庫(kù)系統(tǒng)時(shí)進(jìn)行合理設(shè)置,提高查詢統(tǒng)計(jì)的速度。本文結(jié)合筆者的項(xiàng)目開發(fā)經(jīng)驗(yàn),闡述具體的設(shè)置方法。

  以oracle7.33數(shù)據(jù)庫(kù)系統(tǒng)為例,我們?cè)陂_發(fā)大型oracle數(shù)據(jù)庫(kù)系統(tǒng)時(shí)結(jié)合項(xiàng)目的特點(diǎn),本著安全、高效的原則對(duì)數(shù)據(jù)庫(kù)進(jìn)行了一些物理設(shè)計(jì),從而大大提高了數(shù)據(jù)庫(kù)的查詢統(tǒng)計(jì)速度??偨Y(jié)為如下幾點(diǎn):

  1)擴(kuò)大數(shù)據(jù)表空間到500M,用于存放本系統(tǒng)的數(shù)據(jù);

  2)段盤區(qū)的初始大小為10K,增長(zhǎng)大小為10K,增長(zhǎng)幅度為1;

  3)用戶臨時(shí)空間增大40M;

  4)系統(tǒng)臨時(shí)表空間和回滾段表空間增大40M,并且新建4個(gè)回滾段;

  5)需要經(jīng)常聯(lián)結(jié)查詢,而且數(shù)據(jù)量又大的庫(kù)存表、名錄表、收發(fā)料表放在一簇內(nèi);

  6)提供定時(shí)備份,備份文件放在另外的機(jī)器上。

  設(shè)置數(shù)據(jù)表空間的SQL語(yǔ)句如下:


  CREATE?TABLESPACE?WXGL_DATA1?DATAFILE?'WXGL_DATA1.ORA'?SIZE?500M?ONLINE;

  增加系統(tǒng)臨時(shí)表空間和回滾段表空間的SQL語(yǔ)句如下:


  ALTER?TABLESPACE?TEMPORARY_DATA?ADD?DATAFILE?'TMP2ORCL.ORA'?SIZE?40M;
  ALTER?TABLESPACE?ROLLBACK_DATA?ADD?DATAFILE?'RBS2ORCL.ORA'?SIZE?40M;

  將數(shù)據(jù)空間設(shè)置在指定的數(shù)據(jù)文件的SQL語(yǔ)句如下:


  CREATE?USER?ZBGL?IDENTIFIED?BY?ZBGL;
  GRANT?DBA?TO?ZBGL;
  ALTER?USER?ZBGL?DEFAULT?TABLESPACE?WXGL_DATA1?TEMPORARY?TABLESPACE?TEMPORARY_DATA;?1.?設(shè)置五個(gè)回滾段的SQL語(yǔ)句如下:
  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ù)量大的庫(kù)存表等放在一簇內(nèi)的SQL語(yǔ)句如下:


  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ù)量的庫(kù)存表等放在WXGL_DATA1)
  QCFL?=?'CREATE?TABLE?QC_QCFL?'
  +?'(FLBH?NUMBER(2)?PRIMARY?KEY,'
  +?'?FLMC?VARCHAR(20)?'
  +?'?)?'
  +'?TABLESPACE?WXGL_DATA2?'?;(其他表放在WXGL_DATA2

關(guān)鍵詞標(biāo)簽:ORACLE數(shù)據(jù)庫(kù)

相關(guān)閱讀

文章評(píng)論
發(fā)表評(píng)論

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

相關(guān)下載

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