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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 运维知识 > 数据库 >内容正文

数据库

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

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

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ā)時(shí),這種寫法是會(huì)導(dǎo)致全表掃描的,用不上索引,不知道Sql Server里是否也是一樣呢,于是做一個(gè)簡(jiǎn)單的測(cè)試

1、建立測(cè)試用的表結(jié)構(gòu)和索引:

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

go

CREATE INDEX idx_age ON aaa (age)

GO

2、插入1萬(wàn)條測(cè)試數(shù)據(jù):

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í)行計(jì)劃顯示:

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

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

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

測(cè)試結(jié)果如下:

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

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

建議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

當(dāng)然,如果只有一個(gè)條件,可以設(shè)計(jì)成2條SQL,比如:

DECLARE @i INT;

SET @i=100

IF @i IS NOT NULL

SELECT * FROM aaa WHERE age = @i

ELSE

SELECT * FROM aaa

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

總結(jié)

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

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。