Oracle高水位線(HWM)及性能優(yōu)化

ORACLE在邏輯存儲上分4個粒度:表空間,段,區(qū)和塊.
  • 塊:是粒度最小的存儲單位,現(xiàn)在標(biāo)準(zhǔn)的塊大小是8K,ORACLE每一次I/O操作也是按塊來操作的,也就是說當(dāng)ORACLE從數(shù)據(jù)文件讀數(shù)據(jù)時,是讀取多少個塊,而不是多少行.
  • 區(qū):由一系列相鄰的塊而組成,這也是ORACLE空間分配的基本單位,舉個例子來說,當(dāng)我們創(chuàng)建一個表PM_USER時,首先ORACLE會分配一區(qū)的空間給這個表,隨著不斷的INSERT數(shù)據(jù)到PM_USER,原來的這個區(qū)容不下插入的數(shù)據(jù)時,ORACLE是以區(qū)為單位進(jìn)行擴(kuò)展的,也就是說再分配多少個區(qū)給PM_USER,而不是多少個塊.
  • 段:是由一系列的區(qū)所組成,一般來說,當(dāng)創(chuàng)建一個對象時(表,索引),就會分配一個段給這個對象.所以從某種意義上來說,段就是某種特定的數(shù)據(jù).如CREATE TABLE PM_USER,這個段就是數(shù)據(jù)段,而CREATE INDEX ON PM_USER(NAME),ORACLE同樣會分配一個段給這個索引,但這是一個索引段了.查詢段的信息可以通過數(shù)據(jù)字典: SELECT * FROM USER_SEGMENTS來獲得,
  • 表空間:包含段,區(qū)及塊.表空間的數(shù)據(jù)物理上儲存在其所在的數(shù)據(jù)文件中.一個數(shù)據(jù)庫至少要有一個表空間.
確定碎片程度
  SELECT table_name,
         ROUND ( (blocks * 8), 2) "高水位空間 k",
         ROUND ( (num_rows * avg_row_len / 1024), 2) "真實(shí)使用空間 k",
         ROUND ( (blocks * 10 / 100) * 8, 2) "預(yù)留空間(pctfree) k",
         ROUND (
            (  blocks * 8
             - (num_rows * avg_row_len / 1024)
             - blocks * 8 * 10 / 100),
            2)
            "浪費(fèi)空間 k"
    FROM user_tables
   WHERE temporary = 'N'
ORDER BY 5 DESC;
查看表上次收集統(tǒng)計信息時間
 select table_name,last_analyzed from dba_tables where owner = 'SCHEMA_NAME';
  • 整理表,不影響DML操作
SQL> alter table TABLE_NAME enable ROW MOVEMENT;--啟動行移動功能
SQL> alter table TABLE_NAME shrink space compact;  --只整理碎片 不回收空間
SQL> alter table TABLE_NAME disable ROW MOVEMENT;--關(guān)閉行移動

如果要同時壓縮表的索引,可以發(fā)布:ALTER TABLE TEST_TAB SHRINK SPACE CASCADE

  • 重置高水位喻粹,此時不能有DML操作
SQL> alter table TABLE_NAME enable ROW MOVEMENT;--啟動行移動功能
SQL> alter table TABLE_NAME shrink space; --整理碎片并回收空間,并調(diào)整水位線舌稀。業(yè)務(wù)少時執(zhí)行
SQL> alter table TABLE_NAME disable ROW MOVEMENT;--關(guān)閉行移動
  • shrink 的優(yōu)勢:
    不需要重建索引。
    可以在線操作
釋放表的高水位通常有如下幾種辦法:
  • 對表進(jìn)行MOVE操作:ALTER TABLE TABLE_NAME MOVE;卧檐。若表上存在索引杈女,則記得重建索引。
  • 對表進(jìn)行SHRINK SPACE操作:ALTER TABLE TABLE_NAME SHRINK SPACE;呈昔,注意,在執(zhí)行該指令之前必須開啟行移動:ALTER TABLE TABLE_NAME ENABLE ROW MOVEMENT;友绝。該方法的優(yōu)點(diǎn)是:在碎片整理結(jié)束后堤尾,表上相關(guān)的索引仍然有效,缺點(diǎn)是會產(chǎn)生大量的UNDO和REDO迁客。
  • 復(fù)制要保留的數(shù)據(jù)到臨時表T郭宝,DROP原表,然后RENAME臨時表T為原表掷漱。
  • exp/imp或expdp/impdp重構(gòu)表粘室。
  • 若表中沒有數(shù)據(jù)則直接使用TRUNCATE來釋放高水位。
如何找出系統(tǒng)中哪些表擁有高水位呢卜范?
  • 比較表的行數(shù)和表的大小關(guān)系衔统。如果行數(shù)為0,而表的當(dāng)前占用大小減去初始化時的大泻Q(INITIAL_EXTENT)后依然很大缰冤,那么說明該表有高水位。
  • 行數(shù)和塊數(shù)的比率喳魏,即查看一個塊可以存儲多少行數(shù)據(jù)。如果一個塊存儲的行數(shù)少于5行甚至更少怀薛,那么說明有高水位刺彩。
    注意:
    這兩種方法都不是十分準(zhǔn)確,需要再對查詢結(jié)果進(jìn)行篩選枝恋。需要注意的是创倔,在查詢表的高水位時,首先需要分析表焚碌,以得到最準(zhǔn)確的統(tǒng)計信息畦攘。
SELECT OWNER,

       SEGMENT_NAME TABLE_NAME,

       SEGMENT_TYPE,

       GREATEST(ROUND(100 * (NVL(HWM - AVG_USED_BLOCKS, 0) /

                      GREATEST(NVL(HWM, 1), 1)),

                      2),

                0) WASTE_PER

  FROM (SELECT A.OWNER OWNER,

               A.SEGMENT_NAME,

               A.SEGMENT_TYPE,

               B.LAST_ANALYZED,

               A.BYTES,

               B.NUM_ROWS,

               A.BLOCKS BLOCKS,

               B.EMPTY_BLOCKS EMPTY_BLOCKS,

               A.BLOCKS - B.EMPTY_BLOCKS - 1 HWM,

               DECODE(ROUND((B.AVG_ROW_LEN * NUM_ROWS *

                            (1 + (PCT_FREE / 100))) / C.BLOCKSIZE,

                            0),

                      0,

                      1,

                      ROUND((B.AVG_ROW_LEN * NUM_ROWS *

                            (1 + (PCT_FREE / 100))) / C.BLOCKSIZE,

                            0)) + 2 AVG_USED_BLOCKS,

               ROUND(100 *

                     (NVL(B.CHAIN_CNT, 0) / GREATEST(NVL(B.NUM_ROWS, 1), 1)),

                     2) CHAIN_PER,

               B.TABLESPACE_NAME O_TABLESPACE_NAME

          FROM SYS.DBA_SEGMENTS A, SYS.DBA_TABLES B, SYS.TS$ C

         WHERE A.OWNER = B.OWNER

           AND SEGMENT_NAME = TABLE_NAME

           AND SEGMENT_TYPE = 'TABLE'

           AND B.TABLESPACE_NAME = C.NAME)

 WHERE GREATEST(ROUND(100 * (NVL(HWM - AVG_USED_BLOCKS, 0) /

                      GREATEST(NVL(HWM, 1), 1)),

                      2),

                0) > 50

   AND OWNER NOT LIKE '%SYS%'

   AND BLOCKS > 100

 ORDER BY WASTE_PER DESC;
SELECT D.OWNER,

       ROUND(D.NUM_ROWS / D.BLOCKS, 2),

       D.NUM_ROWS,

       D.BLOCKS,

       D.TABLE_NAME,

 ROUND((d.BLOCKS*8-D.INITIAL_EXTENT/1024)/1024)  t_size

  FROM DBA_TABLES D

 WHERE D.BLOCKS > 10

   AND ROUND(D.NUM_ROWS / D.BLOCKS, 2) < 5

 AND d.OWNER NOT LIKE '%SYS%' ;
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市十电,隨后出現(xiàn)的幾起案子知押,更是在濱河造成了極大的恐慌叹螟,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件台盯,死亡現(xiàn)場離奇詭異罢绽,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)静盅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門良价,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人蒿叠,你說我怎么就攤上這事明垢。” “怎么了市咽?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵痊银,是天一觀的道長。 經(jīng)常有香客問我魂务,道長曼验,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任粘姜,我火速辦了婚禮鬓照,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘孤紧。我一直安慰自己豺裆,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布号显。 她就那樣靜靜地躺著臭猜,像睡著了一般。 火紅的嫁衣襯著肌膚如雪押蚤。 梳的紋絲不亂的頭發(fā)上蔑歌,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機(jī)與錄音揽碘,去河邊找鬼次屠。 笑死,一個胖子當(dāng)著我的面吹牛雳刺,可吹牛的內(nèi)容都是我干的劫灶。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼掖桦,長吁一口氣:“原來是場噩夢啊……” “哼本昏!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起枪汪,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤涌穆,失蹤者是張志新(化名)和其女友劉穎怔昨,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蒲犬,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡朱监,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了原叮。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赫编。...
    茶點(diǎn)故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖奋隶,靈堂內(nèi)的尸體忽然破棺而出擂送,到底是詐尸還是另有隱情,我是刑警寧澤唯欣,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布嘹吨,位于F島的核電站,受9級特大地震影響境氢,放射性物質(zhì)發(fā)生泄漏蟀拷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一萍聊、第九天 我趴在偏房一處隱蔽的房頂上張望问芬。 院中可真熱鬧,春花似錦寿桨、人聲如沸此衅。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽挡鞍。三九已至,卻和暖如春预烙,著一層夾襖步出監(jiān)牢的瞬間墨微,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工扁掸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留欢嘿,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓也糊,卻偏偏與公主長得像,于是被迫代替她去往敵國和親羡宙。 傳聞我的和親對象是個殘疾皇子狸剃,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評論 2 355