首页 > 资讯列表 > 编程/数据库 >> 数据库操作教程

SQL Server ISNULL 不生效原因及解决

数据库操作教程 2022-11-07 15:05:21 转载来源: 网络整理/侵权必删

目录SQLServerISNULL不生效原因问题原因解决方法SQLServerISNULL 真是个坑,CPU飙升90%+SQLServerISNULL不生效原因数据库:SQLServer2008R2原始SQL:historyval字段没有数据显示为NULL,用ISNULL判断为NULL的时候替换为0.0SELECT   ISNULL(historyval,0.0)FROM   ce_bf_l_energyh_t_2WHERE   tagname='123'问题用ISNULL只后数据依旧为NULL并没有替换掉。原因ISNULL只作用于查询出数据后字段为NULL可以替换生效、如果查询的时候这条数据本身为NULL、字段替换时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_2WHERE    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 ISNULL 生效 原因 解决


声明:本文内容来源自网络,文字、图片等素材版权属于原作者,平台转载素材出于传递更多信息,文章内容仅供参考与学习,切勿作为商业目的使用。如果侵害了您的合法权益,请您及时与我们联系,我们会在第一时间进行处理!我们尊重版权,也致力于保护版权,站搜网感谢您的分享!

站长搜索

http://www.adminso.com

Copyright @ 2007~2025 All Rights Reserved.

Powered By 站长搜索

打开手机扫描上面的二维码打开手机版


使用手机软件扫描微信二维码

关注我们可获取更多热点资讯

站长搜索目录系统技术支持