SQL?Server?ISNULL?不生效原因及解決
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),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)系型數(shù)據(jù)庫與非關(guān)系型數(shù)據(jù)庫簡介
數(shù)據(jù)庫有很多種類型,本文對常用的各大關(guān)系型數(shù)據(jù)庫(例如:Oracol、SQLSer、mysql等)和非關(guān)系型數(shù)據(jù)庫(例如:MongoDB、Cassandra、Hadoop HBase等)的優(yōu)勢和缺點(diǎn)做了詳細(xì)的分類分析介紹說明2021-08-08
深入SQL截取字符串(substring與patindex)的詳解
本篇文章是對SQL截取字符串(substring與patindex的使用)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
MSSQLSERVER不同版本設(shè)置開啟遠(yuǎn)程連接(sa配置)
這篇文章主要為大家詳細(xì)介紹了MSSQLSERVER不同版本設(shè)置開啟遠(yuǎn)程連接,包括SQL SERVER 2008/2012/2012R2/2014開啟遠(yuǎn)程連接的設(shè)置方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03
SQLServer 數(shù)據(jù)庫故障修復(fù)頂級技巧之一
SQL Server 2005 和 2008 有幾個關(guān)于高可用性的選項(xiàng),如日志傳輸、副本和數(shù)據(jù)庫鏡像。2010-04-04
sql server 2000阻塞和死鎖問題的查看與解決方法
在實(shí)際引用當(dāng)中,數(shù)據(jù)庫阻塞和死鎖在程序開發(fā)過程經(jīng)常出現(xiàn),下面通過介紹數(shù)據(jù)庫阻塞和數(shù)據(jù)庫死鎖,并提供查看和解決阻塞和死鎖的方法2014-01-01
SQL Server 中調(diào)整自增字段的當(dāng)前初始值
SQL Server 中調(diào)整自增字段的當(dāng)前初始值...2007-01-01
SQLServer數(shù)據(jù)庫從高版本降級到低版本實(shí)例詳解
這篇文章主要介紹了SQLServer數(shù)據(jù)庫從高版本降級到低版本實(shí)例詳解的相關(guān)資料,在工程項(xiàng)目需要遷移的時候,偶爾會用到這樣的知識,需要的朋友可以參考下2016-12-12

