SQL Server ISNULL 不生效原因及解決
目錄
- SQL Server ISNULL 不生效原因
- 問(wèn)題
- 原因
- 解決方法
- SQL Server ISNULL 真是個(gè)坑,CPU飆升90% +
SQL Server ISNULL 不生效原因
數(shù)據(jù)庫(kù):SQL Server 2008 R2
原始SQL:historyval 字段沒(méi)有數(shù)據(jù)顯示為NULL,用ISNULL判斷為NULL的時(shí)候替換為 0.0
SELECT ?? ?ISNULL(historyval, 0.0) FROM ?? ?ce_bf_l_energyh_t_2 WHERE ?? ?tagname = "123"
問(wèn)題
用ISNULL只后數(shù)據(jù)依舊為NULL并沒(méi)有替換掉。
原因
ISNULL只作用于查詢出數(shù)據(jù)后字段為NULL可以替換生效、如果查詢的時(shí)候這條數(shù)據(jù)本身為NULL、字段替換時(shí)ISNULL則不生效。
解決方法
先用 if exists(結(jié)果集)判斷這條數(shù)據(jù)是否存在(也就是說(shuō)這條select這條sql有沒(méi)有結(jié)果集),BEGIN 表示語(yǔ)句塊的開始;END 表示語(yǔ)句塊的結(jié)束(加不加 BEGIN END 代碼塊都可以)。
如果滿足條件直接在下方寫 SQL。
不滿足條件時(shí),則在 ELSE 下方寫 SQL。如此,數(shù)據(jù)進(jìn)行了替換。
IF EXISTS ( ?? ?SELECT ?? ??? ?ISNULL(historyval, 0.0) ?? ?FROM ?? ??? ?ce_bf_l_energyh_t_2 ?? ?WHERE ?? ??? ?tagname = "123" ) BEGIN ?? ?--如果存在 ?? ?SELECT ?? ??? ?ISNULL(historyval, 0.0) ?? ?FROM ?? ??? ?ce_bf_l_energyh_t_2 ?? ?WHERE ?? ??? ?tagname = "123" ?? ?END ?? ?ELSE ? ?? ?BEGIN ?? ??? ?--如果不存在 ?? ??? ?SELECT ?? ??? ??? ?0.0 ?? ??? ?END
SQL Server ISNULL 真是個(gè)坑,CPU飆升90% +
- table1大概1100多萬(wàn)數(shù)據(jù)
- table2大概80多萬(wàn)數(shù)據(jù)
MES系統(tǒng),使用了以下SQL語(yǔ)句,并且這個(gè)語(yǔ)句每分鐘終端會(huì)并發(fā)執(zhí)行一次(大概30個(gè)客戶端)
SELECT ? ? AA.id? FROM ? ?table1 aa ? ? LEFT JOIN table2 ?bb ON bb.No= aa.No? WHERE
--就下面這句,把服務(wù)器CPU干到90%多
isnull( aa.fanCode,"0")!="0"?
修改為 :aa.fanCode IS NOT NULL 后CPU回到個(gè)位數(shù)。
總結(jié):盡量少用isnull()函數(shù),就算用也盡量不用在where后面。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持。
