自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

SQL Server中存儲(chǔ)過程慢于SQL語(yǔ)句直接執(zhí)行的原因

數(shù)據(jù)庫(kù) SQL Server
SQL Server數(shù)據(jù)庫(kù)中,存儲(chǔ)過程的執(zhí)行總是要比SQL語(yǔ)句直接執(zhí)行要慢,這究竟是為什么呢?本文將帶您尋找答案。

SQL Server數(shù)據(jù)庫(kù)中,存儲(chǔ)過程的執(zhí)行總是要比SQL語(yǔ)句直接執(zhí)行要慢,這究竟是為什么呢?本文將帶您尋找答案。

在SQL Server中有一個(gè)叫做 “Parameter sniffing”的特性。SQL Server在存儲(chǔ)過程執(zhí)行之前都會(huì)制定一個(gè)執(zhí)行計(jì)劃。在上面的例子中,SQL在編譯的時(shí)候并不知道@thedate的值是多少,所以它在執(zhí)行執(zhí)行計(jì)劃的時(shí)候就要進(jìn)行大量的猜測(cè)。假設(shè)傳遞給@thedate的參數(shù)大部分都是非空字符串,而FACT表中有40%的thedate字段都是null,那么SQL Server就會(huì)選擇全表掃描而不是索引掃描來對(duì)參數(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)@thedate的sql語(yǔ)句全部用@variable來代替。
<!--(2) 將受影響的sql語(yǔ)句隱藏起來,比如:
<!-- a)      將受影響的sql語(yǔ)句放到某個(gè)子存儲(chǔ)過程中,比如我們?cè)贎thedate設(shè)置成為今天后再調(diào)用一個(gè)字存儲(chǔ)過程將@thedate作為參數(shù)傳入就可以了。
<!-- b)      使用sp_executesql來執(zhí)行受影響的sql。執(zhí)行計(jì)劃不會(huì)被執(zhí)行,除非sp_executesql語(yǔ)句執(zhí)行完。
<!-- c)      使用動(dòng)態(tài)sql(”EXEC(@sql)”來執(zhí)行受影響的sql。
采用(1)的方法改造例子中的存儲(chǔ)過程,如下:

代碼:

ALTER PROCEDURE [dbo].[pro_ImAnalysis_daily]@var_thedate VARCHAR(30) ASBEGIN    declare @THEDATE VARCHAR(30)    IF @var_thedate IS NULL    BEGIN       SET @var_thedate=CONVERT(VARCHAR(30),GETDATE()-1,112);    END      SET @THEDATE=@var_thedate;    DELETE FROM RPT_IM_USERINFO_DAILY WHERE THEDATE=@THEDATE;    INSERT RPT_IM_USERINFO_DAILY (THEDATE,ALLUSER,NEWUSER)    SELECT AA.THEDATE,ALLUSER,NEWUSER    FROM    ( ( SELECT THEDATE,COUNT(DISTINCT USERID) ALLUSER       FROM FACT       WHERE THEDATE=@THEDATE        GROUP BY THEDATE       ) AA       LEFT JOIN       (SELECT THEDATE,COUNT(DISTINCT USERID) NEWUSER        FROM FACT T1        WHERE NOT EXISTS(                         SELECT 1                         FROM FACT T2                         WHERE T2.THEDATE<@THEDATE                             AND T1.USERID=T2.USERID)              AND T1.THEDATE=@THEDATE        GROUP BY THEDATE        ) BB       ON AA.THEDATE=BB.THEDATE);GO
 

【編輯推薦】

SQL SERVER數(shù)據(jù)庫(kù)中存儲(chǔ)過程使用循環(huán)語(yǔ)句

Sql Server兩個(gè)版本中顯示所有表信息的語(yǔ)句

SQL Server中一個(gè)語(yǔ)句塊實(shí)現(xiàn)多條語(yǔ)句插入的方法

SQL Server數(shù)據(jù)庫(kù)用戶創(chuàng)建的方法(使用SQL語(yǔ)句)

使用SQL語(yǔ)句查看SQL Server事務(wù)日志的方法

 

責(zé)任編輯:段燃 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-11-12 09:58:34

SQL存儲(chǔ)過程

2010-11-04 09:43:46

LINQ to SQL

2010-09-07 11:41:24

SQL語(yǔ)句

2010-09-03 15:08:03

SQLselect語(yǔ)句

2010-09-06 11:05:05

SQL SERVER語(yǔ)句

2010-07-15 12:38:14

SQL Server存

2010-09-25 16:21:41

SQL語(yǔ)句

2011-04-02 16:39:53

SQL Server查詢

2009-08-06 16:44:06

2010-09-07 15:12:25

SQL語(yǔ)句優(yōu)化

2011-03-24 13:38:47

SQL Server 存儲(chǔ)分頁(yè)

2010-09-06 11:46:03

SQL Server語(yǔ)句

2010-04-29 14:06:40

Oracle SQL

2009-11-05 18:07:33

Oracle導(dǎo)出sql

2010-11-12 09:18:13

SQL Server存

2011-05-20 15:59:06

Oracle存儲(chǔ)Sql語(yǔ)句

2010-09-14 10:36:23

sql server存

2011-03-28 10:46:36

sql server存儲(chǔ)分頁(yè)

2010-09-07 16:46:56

SQL語(yǔ)句nsert

2011-07-14 13:38:34

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)