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
问题用ISNULL只后数据依旧为NULL并没有替换掉。 原因ISNULL只作用于查询出数据后字段为NULL可以替换生效、如果查询的时候这条数据本身为NULL、字段替换时ISNULL则不生效。 解决方法先用 if exists(结果集)判断这条数据是否存在(也就是说这条select这条sql有没有结果集),BEGIN 表示语句块的开始;END 表示语句块的结束(加不加 BEGIN END 代码块都可以)。 如果满足条件直接在下方写 SQL。 不满足条件时,则在 ELSE 下方写 SQL。如此,数据进行了替换。
SQL Server ISNULL 真是个坑,CPU飙升90% +
MES系统,使用了以下SQL语句,并且这个语句每分钟终端会并发执行一次(大概30个客户端)
--就下面这句,把服务器CPU干到90%多
修改为 :aa.fanCode IS NOT NULL 后CPU回到个位数。 总结:尽量少用isnull()函数,就算用也尽量不用在where后面。 |
2021-10-16
2022-09-14
2022-08-25
2022-03-01
2022-08-25