成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SQL Server中存儲過程慢于SQL語句直接執行的原因

數據庫 SQL Server
SQL Server數據庫中,存儲過程的執行總是要比SQL語句直接執行要慢,這究竟是為什么呢?本文將帶您尋找答案。

SQL Server數據庫中,存儲過程的執行總是要比SQL語句直接執行要慢,這究竟是為什么呢?本文將帶您尋找答案。

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

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

有兩種方式能夠避免出現“Parameter sniffing”問題:
<!--(1)通過使用declare聲明的變量來代替參數:使用set @variable=@thedate的方式,將出現@thedate的sql語句全部用@variable來代替。
<!--(2) 將受影響的sql語句隱藏起來,比如:
<!-- a)      將受影響的sql語句放到某個子存儲過程中,比如我們在@thedate設置成為今天后再調用一個字存儲過程將@thedate作為參數傳入就可以了。
<!-- b)      使用sp_executesql來執行受影響的sql。執行計劃不會被執行,除非sp_executesql語句執行完。
<!-- c)      使用動態sql(”EXEC(@sql)”來執行受影響的sql。
采用(1)的方法改造例子中的存儲過程,如下:

代碼:

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數據庫中存儲過程使用循環語句

Sql Server兩個版本中顯示所有表信息的語句

SQL Server中一個語句塊實現多條語句插入的方法

SQL Server數據庫用戶創建的方法(使用SQL語句)

使用SQL語句查看SQL Server事務日志的方法

 

責任編輯:段燃 來源: 互聯網
相關推薦

2010-11-12 09:58:34

SQL存儲過程

2010-11-04 09:43:46

LINQ to SQL

2010-09-07 11:41:24

SQL語句

2010-09-03 15:08:03

SQLselect語句

2010-07-15 12:38:14

SQL Server存

2010-09-06 11:05:05

SQL SERVER語句

2011-04-02 16:39:53

SQL Server查詢

2010-09-25 16:21:41

SQL語句

2009-08-06 16:44:06

2010-09-07 15:12:25

SQL語句優化

2011-03-24 13:38:47

SQL Server 存儲分頁

2010-09-06 11:46:03

SQL Server語句

2010-04-29 14:06:40

Oracle SQL

2009-11-05 18:07:33

Oracle導出sql

2010-11-12 09:18:13

SQL Server存

2010-09-14 10:36:23

sql server存

2011-03-28 10:46:36

sql server存儲分頁

2011-05-20 15:59:06

Oracle存儲Sql語句

2010-09-07 16:46:56

SQL語句nsert

2010-11-10 13:03:15

SQL Server存
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品一区二区三区久久久 | 欧美日韩国产一区 | 综合久久一区 | 91天堂网 | 日韩欧美一区二区三区四区 | 亚洲a视频| 超碰97av| 9999精品视频| 成人欧美一区二区三区在线观看 | 91久久精品 | 天天插日日操 | 欧美精品久久久久 | 精品9999| 日批免费观看 | 在线成人| 视频一区在线 | 欧美一级二级视频 | 国产成人免费视频网站视频社区 | 国产小视频在线看 | 日韩一区二区在线播放 | 美女视频黄色的 | 国产精品美女久久久久久免费 | 中文字幕亚洲欧美 | 国产精彩视频在线观看 | 黄色一级在线播放 | 久久av影院| 精品粉嫩aⅴ一区二区三区四区 | 久久久久久国产精品免费免费 | 国产精品一区在线 | 黄色播放| 国产成人精品免费视频大全最热 | 亚洲精品1区 | 亚洲一区二区三区免费在线观看 | 色又黄又爽网站www久久 | 中文字幕在线观看日韩 | 一区二区av | 91豆花视频 | 美女国产 | 午夜一级黄色片 | 中文字幕高清一区 | 国产精品久久久爽爽爽麻豆色哟哟 |