SQL?Server?ISNULL?不生效原因及解决
(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun)
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后面。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持程序员之家。
相关文章
SQL?Server中T-SQL标识符介绍与无排序生成序号的方法
这篇文章介绍了SQL?Server中T-SQL标识符与无排序生成序号的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-05-05Sql server 2012 中文企业版安装图文教程(附下载链接)
这篇文章主要介绍了Sql server 2012 中文企业版安装图文教程(附下载链接),需要的朋友可以参考下2020-04-04SQLServer 2012中设置AlwaysOn解决网络抖动导致的提交延迟问题
这篇文章主要介绍了SQLServer 2012中设置AlwaysOn解决网络抖动导致的提交延迟问题,需要的朋友可以参考下2015-02-02SQLServer:探讨EXEC与sp_executesql的区别详解
本篇文章是对EXEC与sp_executesql的区别进行了详细的分析介绍,需要的朋友参考下2013-06-06
最新评论