欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

SQL?Server?ISNULL?不生效原因及解決

 更新時(shí)間:2022年09月26日 14:18:27   作者:liangM_chen  
這篇文章主要介紹了SQL?Server?ISNULL?不生效原因及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

SQL Server ISNULL 不生效原因

數(shù)據(jù)庫(kù):SQL Server 2008 R2

原始SQL:historyval 字段沒有數(shù)據(jù)顯示為NULL,用ISNULL判斷為NULL的時(shí)候替換為 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í)候這條數(shù)據(jù)本身為NULL、字段替換時(shí)ISNULL則不生效。

解決方法

先用 if exists(結(jié)果集)判斷這條數(shù)據(jù)是否存在(也就是說這條select這條sql有沒有結(jié)果集),BEGIN 表示語句塊的開始;END 表示語句塊的結(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多萬數(shù)據(jù)
  • table2大概80多萬數(shù)據(jù)

MES系統(tǒng),使用了以下SQL語句,并且這個(gè)語句每分鐘終端會(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è)參考,也希望大家多多支持腳本之家。 

相關(guān)文章

最新評(píng)論