使用參數的SQL Server查詢比使用常量字符串的查詢花費的時間更長 [英] SQL Server query takes longer with parameter than with constant string

查看:0
本文介紹了使用參數的SQL Server查詢比使用常量字符串的查詢花費的時間更長的處理方法,對大家解決問題具有一定的參考價值,需要的朋友們下面隨著小編來一起學習吧!

問題描述

我在使用MS SQL Server 2008時遇到問題:

當我使用硬編碼字符串作為參數執行查詢時,我的查詢運行得很快,但當我使用字符串參數時,查詢花費的時間更長!
常量字符串查詢花費1秒,而另一個花費11秒。

代碼如下:

常量字符串(1秒):

     SELECT * 
FROM   VIEWCONTENTS 
WHERE  COUNTRY = 'ZA' 
       AND CONTENTTYPE = 'A' 
       AND TASK = 'R23562'; 

參數化(11秒):

DECLARE @country AS CHAR(2); 

SET @country = 'ZA'; 

SELECT * 
FROM   VIEWCONTENTS 
WHERE  COUNTRY = @country 
       AND CONTENTTYPE = 'A' 
       AND TASK = 'R23562' 

推薦答案

在查詢末尾使用選項(重新編譯)。所以:

DECLARE @country AS CHAR(2); 

SET @country = 'ZA'; 

SELECT * 
FROM   VIEWCONTENTS 
WHERE  COUNTRY = @country 
       AND CONTENTTYPE = 'A' 
       AND TASK = 'R23562'
OPTION (RECOMPILE)

這篇關于使用參數的SQL Server查詢比使用常量字符串的查詢花費的時間更長的文章就介紹到這了,希望我們推薦的答案對大家有所幫助,也希望大家多多支持IT屋!

查看全文
登錄 關閉
掃碼關注1秒登錄
發送“驗證碼”獲取 | 15天全站免登陸
全免费A级毛片免费看无码播放