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