日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

where is null mysql_SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法

發(fā)布時間:2025/3/11 数据库 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 where is null mysql_SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

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ā)時,這種寫法是會導致全表掃描的,用不上索引,不知道Sql Server里是否也是一樣呢,于是做一個簡單的測試

1、建立測試用的表結構和索引:

CREATE TABLE aaa(id int IDENTITY, NAME VARCHAR(12), age INT)

go

CREATE INDEX idx_age ON aaa (age)

GO

2、插入1萬條測試數據:

DECLARE @i INT;

SET @i=0;

WHILE @i<10000

BEGIN

INSERT INTO aaa (name, age)VALUES(CAST(@i AS VARCHAR), @i)

SET @i=@i+1;

END

GO

3、先開啟執(zhí)行計劃顯示:

在SQL Server Management Studio的查詢窗口里,右擊窗口任意位置,選擇“包含實際的執(zhí)行計劃”:

4、開始測試,用下面的SQL進行測試:

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

測試結果如下:

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

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

建議SQL改成:

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

當然,如果只有一個條件,可以設計成2條SQL,比如:

DECLARE @i INT;

SET @i=100

IF @i IS NOT NULL

SELECT * FROM aaa WHERE age = @i

ELSE

SELECT * FROM aaa

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

總結

以上是生活随笔為你收集整理的where is null mysql_SQL中WHERE变量IS NULL条件导致全表扫描问题的解决方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。