網站首頁 編程語言 正文
SQL Server ISNULL 不生效原因
數據庫:SQL Server 2008 R2
原始SQL:historyval 字段沒有數據顯示為NULL,用ISNULL判斷為NULL的時候替換為 0.0
SELECT
?? ?ISNULL(historyval, 0.0)
FROM
?? ?ce_bf_l_energyh_t_2
WHERE
?? ?tagname = '123'
問題
用ISNULL只后數據依舊為NULL并沒有替換掉。
原因
ISNULL只作用于查詢出數據后字段為NULL可以替換生效、如果查詢的時候這條數據本身為NULL、字段替換時ISNULL則不生效。
解決方法
先用 if exists(結果集)判斷這條數據是否存在(也就是說這條select這條sql有沒有結果集),BEGIN 表示語句塊的開始;END 表示語句塊的結束(加不加 BEGIN ?END 代碼塊都可以)。
如果滿足條件直接在下方寫 SQL。
不滿足條件時,則在 ELSE 下方寫 SQL。如此,數據進行了替換。?
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多萬數據
- table2大概80多萬數據
MES系統,使用了以下SQL語句,并且這個語句每分鐘終端會并發執行一次(大概30個客戶端)
SELECT
? ? AA.id?
FROM
? ?table1 aa
? ? LEFT JOIN table2 ?bb ON bb.No= aa.No?
WHERE
--就下面這句,把服務器CPU干到90%多
isnull( aa.fanCode,'0')!='0'?
修改為 :aa.fanCode IS NOT NULL ?后CPU回到個位數。
總結:盡量少用isnull()函數,就算用也盡量不用在where后面。?
原文鏈接:https://blog.csdn.net/weixin_38941916/article/details/87696738
相關推薦
- 2022-05-20 C++實現商店倉庫管理系統_C 語言
- 2022-08-28 配置zabbix監控nginx狀態,監控華為路由器
- 2022-09-08 Go語言通道之無緩沖通道_Golang
- 2023-04-14 jupyter-lab設置自啟動及遠程連接開發環境_python
- 2022-02-26 Echarts - 更改圖表圖例(legend)自定義顏色(并與數據段顏色對應)
- 2022-04-18 騰訊im中調用 setMessageRead 會話列表中的未讀消息還在存在
- 2024-07-13 IDEA無法使用@WebServlet()注解
- 2022-07-26 react如何添加less環境配置_React
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支