《sql server 性能調(diào)優(yōu),查詢從20秒至2秒》要點:
本文介紹了sql server 性能調(diào)優(yōu),查詢從20秒至2秒,希望對您有用。如果有疑問,可以聯(lián)系我們。
作者:Emrys
出處:http://www.cnblogs.com/emrys5/
文章來自博客園
一、需求
需求很簡單,就是需要查詢一個報表,只有1個表,數(shù)據(jù)量大約60萬左右,但是中間有些邏輯.
先說明一下服務(wù)器配置情況:1核CPU、2GB內(nèi)存、機(jī)械硬盤、Sqlserver 2008 R2、Windows Server2008 R2 SP1和阿里云的服務(wù)器,簡單說就是阿里云最差的服務(wù)器.
1、原始表結(jié)構(gòu)
非常簡單的一張表,這次不討論數(shù)據(jù)冗余和表字段的設(shè)計,如是否可以把Project和Baojian提出成一個表等等,這個是原始表結(jié)構(gòu),這個目前是沒有辦法改變的.
2、查詢的sql語句為
此段sql語句主要的功能是:
1、根據(jù)ProjectNumber, ProjectName, BaojianNumber, BaojianName, ToubiaoPerson分組,查詢所有數(shù)據(jù)的sum(UnitPrice)
其中UnitPrice>MaxPrice的判斷是為了邏輯,如果有一條數(shù)據(jù)滿足,則此分組所有的數(shù)據(jù)不查詢.
2、根據(jù)ProjectNumber, ProjectName, BaojianNumber, BaojianName 分組,查詢所有數(shù)據(jù)的avg(price),以上兩步主要就是為了查詢根據(jù)ProjectNumber, ProjectName, BaojianNumber, BaojianName分組的avg(price)值.
3、然后根據(jù)邏輯獲取相應(yīng)的值、分?jǐn)?shù)和按照分?jǐn)?shù)排序分頁等等操作.
二、性能調(diào)優(yōu)
在未做任何優(yōu)化之前,查詢一次的時間大約為20秒左右.
1、建立索引
根據(jù)sql語句我們可以知道,會根據(jù)5個字段(ProjectNumber, ProjectName, BaojianNumber, BaojianName, ToubiaoPerson)進(jìn)行分組聚合,所以嘗試添加非聚集索引idx_calc.
在索引鍵列添加ProjectNumber, ProjectName, BaojianNumber, BaojianName, ToubiaoPerson.如圖:
然后執(zhí)行查詢sql語句,發(fā)現(xiàn)執(zhí)行時間已經(jīng)減半了,只要10610毫秒.
2、索引包含列
分析查詢sql可以得知,我們需要計算的值只有UnitPrice和MaxPrice,所以想到把UnitPrice和MaxPrice添加到idx_calc的包含列中.如圖
然后執(zhí)行查詢sql語句,發(fā)現(xiàn)執(zhí)行時間再次減半,只要6313毫秒,現(xiàn)在已經(jīng)從之前的20多秒優(yōu)化成6秒多.
3、再次優(yōu)化查詢Sql
再次分析sql語句可以把計算所有數(shù)據(jù)的avg(price)語句暫時放置臨時表(#temp_table)中,再計算其他值的時候直接從臨時表中(#temp_table)獲取數(shù)據(jù).
然后執(zhí)行查詢sql語句,執(zhí)行時間只有2323毫秒.
在硬件、表數(shù)據(jù)量和查詢稍復(fù)雜的情況下,這樣已經(jīng)可以基本上滿足查詢需求了.
三、總結(jié)
經(jīng)過三步:1、建立索引,2、添加包含列,3、用臨時表.用三步可以把查詢時間從20秒優(yōu)化至2秒.
如果對您有幫助,歡迎推薦..
“勤工儉學(xué)計劃”,給你一個真正0元學(xué)習(xí)IT技術(shù)的機(jī)會!
http://www.ujiuye.com/zt/qgjx/?wt.bd=fq37300j
找工作太難?不是你不行,我們來幫你!
http://www.ujiuye.com/zt/jyfc/?wt.bd=fq37300j
交流群:345648424
歡迎參與《sql server 性能調(diào)優(yōu),查詢從20秒至2秒》討論,分享您的想法,維易PHP學(xué)院為您提供專業(yè)教程。
轉(zhuǎn)載請注明本頁網(wǎng)址:
http://www.fzlkiss.com/jiaocheng/7859.html