SQL Server ISNULL 不生效原因及解决
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语句添加删除修改字段、一些表与字段的基本操作、数据库备份等
用SQL语句添加删除修改字段、一些表与字段的基本操作、数据库备份等,需要的朋友可以参考下。2011-11-11Sql Server中一个表2个字段关联同一个表(代码解决)
Sql Server中一个表2个字段关联同一个表(代码解决),需要的朋友可以参考一下2013-02-02MS SQL Server2014链接到MS SQL Server 2000的解决方案及问题处理
在大数据中,我们经常需要用到分布式数据,那么在SqlServer中,我们如何来实现呢,答案就是创建链接服务器!同版本的SqlServer之间的操作网上有很多,今天我们来探讨下不同版本SqlServer之间的链接问题。2014-07-07ASP.NET下向SQLServer2008导入文件实例操作方法
在Microsoft SQL Server2008以后的版本中,将删除image数据类型。在新的开发工作中将不适用此数据类型,并打算修改当前使用此数据类型的应用程序,改用varbinary(max)数据类型。2010-09-09
最新评论