在线播放亚洲第一字幕,国产大片在线观看黄不卡,中文字幕亚洲欧美无线码,日本一区二区视频不卡免费


昂捷論壇≡FAQ≡□-通用類 → [分享][原創(chuàng)]SQL Server中存儲(chǔ)過程比直接運(yùn)行SQL語句慢的原因


  共有27354人關(guān)注過本帖樹形打印

主題:[分享][原創(chuàng)]SQL Server中存儲(chǔ)過程比直接運(yùn)行SQL語句慢的原因

帥哥喲,離線,有人找我嗎?
gqznick
  1樓 個(gè)性首頁 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:下士 帖子:3 積分:158 威望:0 精華:0 注冊:2011/11/1 9:40:53
[分享][原創(chuàng)]SQL Server中存儲(chǔ)過程比直接運(yùn)行SQL語句慢的原因  發(fā)帖心情 Post By:2012/12/28 16:40:02

SQL Server中存儲(chǔ)過程比直接運(yùn)行SQL語句慢的原因:

最近在BI項(xiàng)目中遇到一個(gè)問題,在直接sqlserver中直接 exec up_fact_d_gdsclass ‘2012-12-12’,執(zhí)行時(shí)間大概需要很長時(shí)間,大概20分鐘左右;但是在打開存儲(chǔ)過程取一句一句執(zhí)行代碼確非?,大概2分鐘就可以執(zhí)行完成,相差近10倍;如下:

ALTER PROC [dbo].[up_fact_d_gdsclass]
@dst date
as


select
   a.c_dt,b.c_adno,b.c_child_adno,b.c_class,b.c_child_class,
   a.c_store_id,b.c_type,b.c_tax_rate,
   isnull(sum(c.c_order_n),0) as c_number_order,
   isnull(sum(c.c_at_order),0) as c_at_order,isnull(sum(a.c_ret_n),0) as c_number_ret,
   isnull(sum(a.c_at_in_ret),0) as c_at_ret,isnull(sum(a.c_rec_n),0) as c_number_rec,
   isnull(sum(a.c_at_in_rec),0) as c_at_rec,isnull(sum(a.c_move_in_n),0) as c_number_move_in,

。。。。

在一般我們定義存儲(chǔ)過程的變量的時(shí)候用上面這種方式;

 

ALTER PROC [dbo].[up_fact_d_gdsclass]
@dst date
as


declare @dt date
set @dt=@dst
select
   a.c_dt,b.c_adno,b.c_child_adno,b.c_class,b.c_child_class,
   a.c_store_id,b.c_type,b.c_tax_rate,
   isnull(sum(c.c_order_n),0) as c_number_order,
   isnull(sum(c.c_at_order),0) as c_at_order,isnull(sum(a.c_ret_n),0) as c_number_ret,
   isnull(sum(a.c_at_in_ret),0) as c_at_ret,isnull(sum(a.c_rec_n),0) as c_number_rec,
   isnull(sum(a.c_at_in_rec),0) as c_at_rec,isnull(sum(a.c_move_in_n),0) as c_number_move_in,

。。。

當(dāng)在存儲(chǔ)過程中再聲明一個(gè)變量來接受外部傳入的這個(gè)變量時(shí),執(zhí)行的效率非常高,也可以將內(nèi)部的變量賦一個(gè)缺省值;

 

原因在于:

在SQL Server中有一個(gè)叫做 “Parameter sniffing”的特性。SQL Server在存儲(chǔ)過程執(zhí)行之前都會(huì)制定一個(gè)執(zhí)行計(jì)劃。在上面的例子中,SQL在編譯的時(shí)候并不知道@thedate的值是多少,所以它在執(zhí)行執(zhí)行計(jì)劃的時(shí)候就要進(jìn)行大量的猜測。假設(shè)傳遞給@thedate的參數(shù)大部分都是非空字符串,而FACT表中有40%的thedate字段都是null,那么SQL Server就會(huì)選擇全表掃描而不是索引掃描來對參數(shù)@thedate制定執(zhí)行計(jì)劃。全表掃描是在參數(shù)為空或?yàn)?的時(shí)候最好的執(zhí)行計(jì)劃。但是全表掃描嚴(yán)重影響了性能。

假設(shè)你第一次使用了Exec pro_ImAnalysis_daily @thedate=’20080312’那么SQL Server就會(huì)使用20080312這個(gè)值作為下次參數(shù)@thedate的執(zhí)行計(jì)劃的參考值,而不會(huì)進(jìn)行全表掃描了,但是如果使用@thedate=null,則下次執(zhí)行計(jì)劃就要根據(jù)全表掃描進(jìn)行了。

有兩種方式能夠避免出現(xiàn)“Parameter sniffing”問題:

(1)通過使用declare聲明的變量來代替參數(shù):使用set @variable=@thedate的方式,將出現(xiàn)@thedatesql語句全部用@variable來代替。

(2) 將受影響的sql語句隱藏起來,比如:

a) 將受影響的sql語句放到某個(gè)子存儲(chǔ)過程中,比如我們在@thedate設(shè)置成為今天后再調(diào)用一個(gè)字存儲(chǔ)過程將@thedate作為參數(shù)傳入就可以了。

b) 使用sp_executesql來執(zhí)行受影響的sql。執(zhí)行計(jì)劃不會(huì)被執(zhí)行,除非sp_executesql語句執(zhí)行完。

c) 使用動(dòng)態(tài)sql”EXEC(@sql)”來執(zhí)行受影響的sql。

由此提升了BI在抽取和聚合大數(shù)據(jù)時(shí)的效率。

參考:http://www.cnblogs.com/wuming/archive/2009/05/06/1450980.html

 



查看使用道具詳細(xì)信息
獲贈(zèng)金幣帖,共獲得 0 個(gè)金幣
使用IE9無法添加附件的解決方法 支持(0中立(0反對(0回到頂部
帥哥喲,離線,有人找我嗎?
qwe8520
  2樓 個(gè)性首頁 | 信息 | 搜索 | 郵箱 | 主頁 | UC


加好友 發(fā)短信
等級:下士 帖子:5 積分:85 威望:0 精華:0 注冊:2015/5/14 21:14:26
  發(fā)帖心情 Post By:2015/5/14 21:21:58

學(xué)習(xí)了。。 ブランドコピー私達(dá)がヴィトン激安時(shí)代にグッチ激安従ってベルト激安成長プラダコピーする時(shí)に

贈(zèng)送樓主:0個(gè)金幣
使用IE9無法添加附件的解決方法 支持(0中立(0反對(0回到頂部
国产你懂得网址在线观看| 美女干bi视频| 嫩 穴 骚 逼 屌 操| 痴汉av永久网站aav8| 看美女小jj无遮挡黄片| 国产乱人伦偷精品视频下| 先锋人妻啪啪av资源网站| 视频一区二区 国产精品| 久久激情三级片| 日逼紧水多视频| 国产极品尤物粉嫩在线观看| 欧美老熟妇性xxxxx| 夜夜操亚洲女人| 啊啊啊大鸡吧捅死我视频| 亚洲七十路熟女一区二区| 国产精品久久e热这里热| 日本精品电影一区二区三区| 人人妻人人爽人人综合网| 日韩精品中文字幕你懂的| 无码av喷白浆在线播放| 欧美成人H版中文在线看| 日本激情在线看免费观看| 男生插女孩下面免费网站| 少妇熟女内射一区二区三区| 男生把jj插进女生逼里| 精品国产一区二区三区蜜臀| 玩弄少妇的肉体K8经典| 9l国产自产一区二区三区| 亚洲人成无码网站www| 大肉棒操我视频在线播放| 白丝美女被强奸视频网站| 日本插视频免费| 国产精品制服丝袜第一页| 美女和男的互操黄色网站| 欧美日韩亚洲不卡高清久久| 女生被日到高潮喷水视频| 欧美激情aaa级顶级一区| 美女又黄又爽又色的视频| 美艳人妻办公室抽搐呻吟| 骚逼操啊硬狗鸡巴干视频| 国产一区自拍手机在线观看|