广告位联系
返回顶部
分享到

SQL Server ISNULL 不生效原因及解决方法

MsSql 来源:互联网 作者:佚名 发布时间:2022-09-29 08:59:15 人浏览
摘要

SQL Server ISNULL 不生效原因 数据库:SQL Server 2008 R2 原始SQL:historyval 字段没有数据显示为NULL,用ISNULL判断为NULL的时候替换为 0.0 1 2 3 4 5 6 SELECT ISNULL(historyval, 0.0) FROM ce_bf_l_energyh_t_2 WHERE

SQL Server ISNULL 不生效原因

数据库:SQL Server 2008 R2

原始SQL:historyval 字段没有数据显示为NULL,用ISNULL判断为NULL的时候替换为 0.0

1

2

3

4

5

6

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。如此,数据进行了替换。 

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

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个客户端)

1

2

3

4

5

6

SELECT

    AA.id 

FROM

   table1 aa

    LEFT JOIN table2  bb ON bb.No= aa.No 

WHERE

--就下面这句,把服务器CPU干到90%多

1

isnull( aa.fanCode,'0')!='0' 

修改为 :aa.fanCode IS NOT NULL  后CPU回到个位数。

总结:尽量少用isnull()函数,就算用也尽量不用在where后面。 


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 : https://blog.csdn.net/weixin_38941916/article/details/87696738
相关文章
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计