濮阳杆衣贸易有限公司

主頁 > 知識庫 > SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法

SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法

熱門標(biāo)簽:陽光創(chuàng)信ai外呼獲客系統(tǒng)助力 云南全自動外呼系統(tǒng)公司 競圣地圖標(biāo)注服務(wù) 安陽天音防封電銷卡 外呼系統(tǒng)的話術(shù) 智能外呼系統(tǒng)需要多少錢 智能語音車載電話機(jī)器人 衛(wèi)星地圖標(biāo)注距離 貴州外呼回?fù)芟到y(tǒng)是什么

復(fù)制代碼 代碼如下:

SET @SQL = 'SELECT * FROM Comment with(nolock) WHERE 1=1
    And (@ProjectIds Is Null or ProjectId = @ProjectIds)
    And (@Scores is null or Score =@Scores)'


印象中記得,以前在做Oracle開發(fā)時,這種寫法是會導(dǎo)致全表掃描的,用不上索引,不知道Sql Server里是否也是一樣呢,于是做一個簡單的測試
1、建立測試用的表結(jié)構(gòu)和索引:
復(fù)制代碼 代碼如下:

CREATE TABLE aaa(id int IDENTITY, NAME VARCHAR(12), age INT)
go
CREATE INDEX idx_age ON aaa (age)
GO

2、插入1萬條測試數(shù)據(jù):

復(fù)制代碼 代碼如下:

DECLARE @i INT;
SET @i=0;
WHILE @i10000
BEGIN
  INSERT INTO aaa (name, age)VALUES(CAST(@i AS VARCHAR), @i)
  SET @i=@i+1;
END
GO

3、先開啟執(zhí)行計(jì)劃顯示:
在SQL Server Management Studio的查詢窗口里,右擊窗口任意位置,選擇“包含實(shí)際的執(zhí)行計(jì)劃”:

4、開始測試,用下面的SQL進(jìn)行測試:

復(fù)制代碼 代碼如下:

DECLARE @i INT;
SET @i=100
SELECT * FROM aaa WHERE (@i IS NULL OR age = @i)
SELECT * FROM aaa WHERE (age = @i OR @i IS NULL)
SELECT * FROM aaa WHERE age=isnull(@i, age)
SELECT * FROM aaa WHERE age = @i

測試結(jié)果如下:

可以看到,即使@i有值,不管@i IS NULL是放在前面還是放在后面,都無法用到age的索引,另外age=ISNULL(@i,age)也用不上索引

最終結(jié)論,SQL Server跟ORACLE一樣,如果條件里加了 變量 IS NULL,都會導(dǎo)致全表掃描。

建議SQL改成:

復(fù)制代碼 代碼如下:

DECLARE @i INT;
SET @i=100

DECLARE @sql NVARCHAR(MAX)
SET @sql = 'SELECT * FROM aaa'
IF @i IS NOT NULL
    SET @sql = @sql + ' WHERE age = @i'
EXEC sp_executesql @sql, N'@i int', @i


當(dāng)然,如果只有一個條件,可以設(shè)計(jì)成2條SQL,比如:
復(fù)制代碼 代碼如下:

DECLARE @i INT;
SET @i=100
IF @i IS NOT NULL
    SELECT * FROM aaa WHERE age = @i
ELSE
    SELECT * FROM aaa

但是,如果條件多了,SQL數(shù)目也變得更多,所以建議用EXEC的方案

您可能感興趣的文章:
  • MySQL Where 條件語句介紹和運(yùn)算符小結(jié)
  • MYSQL WHERE語句優(yōu)化
  • MySQL 存儲過程傳參數(shù)實(shí)現(xiàn)where id in(1,2,3,...)示例
  • MySQL左聯(lián)多表查詢where條件寫法示例
  • MySQL 聯(lián)合索引與Where子句的優(yōu)化 提高數(shù)據(jù)庫運(yùn)行效率
  • sql語句中where 1=1的作用
  • MySQL中union和join語句使用區(qū)別的辨析教程
  • SQL語句的并集UNION 交集JOIN(內(nèi)連接,外連接)等介紹
  • 解析sql語句中l(wèi)eft_join、inner_join中的on與where的區(qū)別
  • 解析mysql left( right ) join使用on與where篩選的差異
  • SQL中JOIN和UNION區(qū)別、用法及示例介紹
  • sql join on 用法
  • SQL where條件和jion on條件的詳解及區(qū)別

標(biāo)簽:鄂爾多斯 欽州 湘潭 周口 河源 寧夏 營口 預(yù)約服務(wù)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法》,本文關(guān)鍵詞  SQL,中,WHERE,變量,NULL,條件,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL中WHERE變量IS NULL條件導(dǎo)致全表掃描問題的解決方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    专栏| 游戏| 惠州市| 达孜县| 长寿区| 资源县| 云南省| 揭阳市| 安庆市| 宜阳县| 新昌县| 兴海县| 宜城市| 沾化县| 莎车县| 桐庐县| 林芝县| 聊城市| 南华县| 辉县市| 大安市| 泰和县| 蓬莱市| 云梦县| 淮阳县| 项城市| 柳河县| 准格尔旗| 阜阳市| 建昌县| 娱乐| 弥渡县| 衡阳市| 广昌县| 广平县| 大名县| 丰城市| 兴业县| 玉山县| 平江县| 丽江市|