小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

sql查詢(xún)慢如何下手

 aaie_ 2012-04-19
分析一個(gè)sql查詢(xún)慢的方法:
1、了解查詢(xún)的結(jié)果集與全表的比值
   根據(jù)了解表數(shù)據(jù),可判斷索引是否在查詢(xún)中該用。

   如果是索引沒(méi)用上導(dǎo)致慢的原因,這個(gè)就需要通過(guò)表統(tǒng)計(jì),索引重建,或hint等方式讓其走上索引。

2、重新分析表的統(tǒng)計(jì)信息
   exec dbms_stats.gather_table_stats('GMAP','S_GRID_P_MARKET');--對(duì)整個(gè)表進(jìn)行統(tǒng)計(jì)
   exec dbms_stats.gather_table_stats('GMAP','S_GRID_P_MARKET',estimate_percent=>100,cascade=>true,no_invalidate=>true,
                                       method_opt=>'for columns size skewonly DISTRICTID'); --只對(duì)需要的字段統(tǒng)計(jì)

3、判斷索引是否有效,是否需要重建,分析索引
  analyze index IDX_P_TILE_STREETAREA_ROWCOL validate structure;--分析索引結(jié)構(gòu)
  --查看該索引的相關(guān)信息
  select btree_space, -- if > 8192(塊的大?。?br>        height, -- if > 3
        pct_used, -- if < 75
        del_lf_rows / (decode(lf_rows, 0, 1, lf_rows)) * 100 as deleted_pct -- if > 20%
   from index_stats;
   如果超出了if 后面的值即可能需要進(jìn)行 index rebuild.

4、查看索引或表的碎片程度
--查看索引碎片程度(del_lf_rows與lf_rows的比值)
必須先執(zhí)行 analyze index index_name validate structure;
select name,
       del_lf_rows,
       lf_rows,
       round(del_lf_rows * 100 / decode((lf_rows + del_lf_rows), 0, 1), 2)
  from index_stats;

--查看碎片程度高的表
    SELECT segment_name table_name, COUNT(*) extents
      FROM dba_segments
     WHERE owner NOT IN ('SYS', 'SYSTEM')
     GROUP BY segment_name
    HAVING COUNT(*) = (SELECT MAX(COUNT(*))
                         FROM dba_segments
                        GROUP BY segment_name);
 解決表碎片問(wèn)題:alter table ...move tablespace...

5、查看該sql執(zhí)行中等待事件
oracle9i的話(huà),v$session視圖與v$sql視圖沒(méi)有sql_id字段,可以通過(guò)地址進(jìn)行關(guān)聯(lián),而且關(guān)聯(lián)的時(shí)候要注意sql_address是raw型,而address
是number型,不能直接將v$sql查詢(xún)出來(lái)的address值放到v$session中sql_address字段。
如果是oracle10g則直接用sql_id關(guān)聯(lián)就可以了。
select sid, event
  from v$session_wait
 where sid in
       (select sn.sid
          from v$session sn, v$sql sl
         where sn.sql_address = sl.address
           and sl.sql_text like
               'select gwm_geometry from s_grid_p_market where districtid =1500%');
多執(zhí)行幾次,查看等待時(shí)間的變化情況。

6、并行
 查看并行開(kāi)啟的效果。
 select /*+ parallel(dd,2)*/ gwm_geometry from s_grid_p_market where districtid =1500;
 或者直接對(duì)表啟用并行:alter table s_grid_p_market parallel;
 (取消并行):alter table s_grid_p_market noparallel;

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀(guān)點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶(hù) 評(píng)論公約

    類(lèi)似文章 更多