SQL Server ISNULL 不生效原因及解决
作者:liangM_chen 发布时间:2024-01-13 09:53:34
标签: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后面。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
来源:https://blog.csdn.net/weixin_38941916/article/details/87696738
0
投稿
猜你喜欢
- ancestor:祖先adjacent:相邻algorithm:运算法则anonymous box:无名盒子。例: anonymous in
- 目录1. 画布(canvas) 1.1 设置画布大小2. 画笔 2.1 画笔的状态 2.2 画笔的属性 2.3 绘图命令3. 命令详
- 阅读上一篇:FrontPage XP设计教程1——站点初建与管理接下来的工作就是读者朋友们最为关心的网页的制作和编辑了。我们知道,一个站点是
- MySQL 目前的最新版本是 5.7.11,在 Linux 下提供特定发行版安装包(如 .rpm)以及二进制通用版安装包(.tar.gz)。
- 本文主要研究的是使用Python获取本机所有网卡ip,掩码和广播地址,分享了相关的实例代码,具体介绍如下。搜了一天,竟然没找到一段合适的代码
- 在前文说过,如果想要更好的做接口测试,我们要利用自己的代码基础与代码优势,所以该章节不会再介绍商业化的、通用的接口测试工具,重点介绍如何通过
- 一、什么是Anaconda?Anaconda,中文是大蟒蛇,是一个开源的Anaconda是专注于数据分析的Python发行版本,包含了con
- 目录Show Me The Code测试下效果效果PS另一种方法Show Me The CodeHTMLElement.prototype.
- 昨天翻硬盘,找到一个好东西,可惜自己加了密码自己不记得了。试了几个常用的没试出来,于是写了这么个小脚本来替我尝试。。呵呵,还真给解出来了。p
- 本文实例讲述了Python 闭包,函数分隔作用域,nonlocal声明非局部变量操作。分享给大家供大家参考,具体如下:实例对象也可以实现闭包
- SQL中的单记录函数 1.ASCII 返回与指定的字符对应的十进制数; SQL> select ascii('A')
- 效果如下所示:# -*- coding: utf-8 -*-import turtle# 绘制太极图函数def draw_TJT(R):&n
- Web 前端优化最佳实践第三部分面向 Cookie 。目前只有 2 条实践规则。1. 缩小 Cookie (Reduce Cook
- 一、优先级队列介绍我们知道,普通的队列插入一个元素,数据会被放在后端,并且需要前面所有的元素都处理完成后才会处理前面的数据。但是优先级队列,
- 1:为什么每个layout下都有个inlayout?我们将layout的宽/浮动等属性设置好之后,对于layout内的padding和mar
- 前言:本人遇到一个需求,需要在MySql的字段中截取一段字符串中的特定字符,类似于正则表达式的截取,苦于没有合适的方法,百度之后终于找到一个
- 前言 FTP(File Transfer Protocol)是文件传输协议的简称。用于Internet上的控制文件的双向传输。同时,它也是一
- Tuple 是不可变 list。 一旦创建了一个 tuple 就不能以任何方式改变它。Tuple 与 list 的相同之处定义 tuple
- 环境:1 .Windows Server 2016 Datacenter 64位2 .SQL Server 2016 Enterprise
- 描述的意思是HTML为中心的前端开发也差不多是web标准的意思。1.HTML是基础2.CSS依靠选择符提供视觉;3.Javascript 依