2、插入1萬條測試數(shù)據(jù):
4、開始測試,用下面的SQL進行測試:
可以看到,即使@i有值,不管@i IS NULL是放在前面還是放在后面,都無法用到age的索引,另外age=ISNULL(@i,age)也用不上索引
最終結(jié)論,SQL Server跟ORACLE一樣,如果條件里加了 變量 IS NULL,都會導(dǎo)致全表掃描。
建議SQL改成:
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
但是,如果條件多了,SQL數(shù)目也變得更多,所以建議用EXEC的方案
標簽:鄂爾多斯 欽州 湘潭 周口 河源 寧夏 營口 預(yù)約服務(wù)
巨人網(wǎng)絡(luò)通訊聲明:本文標題《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)。上一篇:SQL cursor用法實例