SQL:MySQL函数:空值处理函数(NULL Handling Functions)

news2025/5/23 11:43:21

目录

什么是空值(NULL)?

常用空值处理函数总览

1️⃣ IFNULL() – 空值替换函数(If Null)

2️⃣ COALESCE() – 多参数空值判断(返回第一个非 NULL 值)

3️⃣ NULLIF() – 相等则返回 NULL(避免错误值)

4️⃣ IS NULL / IS NOT NULL – 判断是否为空

使用场景总结


什么是空值(NULL)?

在 MySQL 中,NULL 表示一个“未知”或“无值”的状态,不是数字 0,也不是空字符串 ''。在处理数据库数据时,我们经常会遇到字段值为 NULL 的情况,这时就需要使用空值处理函数来避免出错。

详细介绍可以看我之前发表的文章:

SQL易错解析:你真的理解 NULL 吗?_sql null-CSDN博客

常用空值处理函数总览

函数名称(英文)中文名称基本语法英文含义含义说明
IFNULL()空值替换函数IFNULL(expr1, expr2)If Null如果 expr1 是 NULL,则返回 expr2,否则返回 expr1
COALESCE()多值优先返回非空值COALESCE(val1, val2, ..., valN)Coalesce(联合)从左到右返回第一个非 NULL 的值
NULLIF()相等则返回 NULLNULLIF(expr1, expr2)Null If Equal如果两个参数相等,则返回 NULL,否则返回第一个参数
IS NULL / IS NOT NULL空值判断expr IS NULL / expr IS NOT NULLIs Null判断一个表达式是否为 NULL,返回布尔值(1/0)

1️⃣ IFNULL() – 空值替换函数(If Null)

  • 英文名称:IFNULL — If Null

  • 中文含义:如果表达式为 NULL,则返回指定的默认值

  • 语法:

IFNULL(expr1, expr2)
  • 解释:常用于处理查询结果中的空值,用默认值替代。

  • 示例:

SELECT name, IFNULL(bonus, 0) AS bonus_value FROM employees;

2️⃣ COALESCE() – 多参数空值判断(返回第一个非 NULL 值)

  • 英文名称:COALESCE — Coalesce (联合、合并)

  • 中文含义:从多个参数中返回第一个非 NULL 的值

  • 语法:

COALESCE(val1, val2, ..., valN)
  • 解释:相比 IFNULL 更灵活,可以处理多个参数,按顺序判断非 NULL。

  • 示例:

SELECT COALESCE(phone, email, '无联系方式') AS contact FROM users;

3️⃣ NULLIF() – 相等则返回 NULL(避免错误值)

  • 英文名称:NULLIF — Null If Equal

  • 中文含义:如果两个表达式相等,返回 NULL;否则返回第一个表达式

  • 语法:

NULLIF(expr1, expr2)
  • 解释:常用于除法操作中,避免除以 0 错误。

  • 示例:

SELECT total / NULLIF(quantity, 0) AS avg_price FROM sales;

4️⃣ IS NULL / IS NOT NULL – 判断是否为空

  • 英文名称:IS NULL — Is Null

  • 中文含义:判断某个值是否为 NULL(或不为 NULL)

  • 语法:

column_name IS NULL
column_name IS NOT NULL
  • 解释:常用于 WHERE 子句中进行空值筛选。

  • 示例:

SELECT * FROM employees WHERE bonus IS NULL;

使用场景总结

应用场景推荐函数示例语句
替换空值为默认值IFNULL()IFNULL(bonus, 0)
多个字段找非空值COALESCE()COALESCE(phone, email)
避免除以 0 错误NULLIF()amount / NULLIF(quantity, 0)
查询空值记录IS NULLWHERE address IS NULL
查询非空值记录IS NOT NULLWHERE birthday IS NOT NULL

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2381948.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

利用ffmpeg截图和生成gif

从视频中截取指定数量的图片 ffmpeg -i input.mp4 -ss 00:00:10 -vframes 1 output.jpgffmpeg -i input.mp4 -ss 00:00:10 -vframes 180 output.jpg -vframes 180代表截取180帧, 实测后发现如果视频是60fps,那么会从第10秒截取到第13秒-i input.mp4:指定输入视频文…

初始化一个Springboot项目

初始化一个Springboot项目 文章目录 初始化一个Springboot项目1、新建项目2、配置yml3、自定义异常4、通用相应类5、全局跨域配置6、总结 1、新建项目 首先,我们需要创建一个新的 Spring Boot 项目。这里我们使用 IntelliJ IDEA 作为开发工具,它提供了方…

YOLOv8在单目向下多车辆目标检测中的应用

大家读完觉得我有帮助记得关注!!! 摘要 自动驾驶技术正逐步改变传统的汽车驾驶方式,标志着现代交通运输的一个重要里程碑。目标检测是自主系统的基石,在提高驾驶安全性、实现自主功能、提高交通效率和促进有效的应急…

Baklib构建AI就绪型知识中台实践

Baklib驱动企业知识资产重构 在数字化转型浪潮中,企业知识中台的构建已成为激活数据价值的关键路径。Baklib通过结构化存储与智能分类引擎,将分散于邮件、文档、IM工具中的碎片化信息转化为可检索、可复用的数字资产。其核心能力体现在三个维度&#xf…

JS逆向-某易云音乐下载器

文章目录 介绍下载链接Robots文件搜索功能JS逆向**函数a:生成随机字符串****函数b:AES-CBC加密****函数c:RSA公钥加密** 歌曲下载总结 介绍 在某易云音乐中,很多歌曲听是免费的,但下载需要VIP,此程序旨在“…

服务器的基础知识

什么是服务器 配置牛、运行稳、价格感人的高级计算机,家用电脑不能比拟的。 服务器的组成:电源、raid卡、网卡、内存、cpu、主板、风扇、硬盘。 服务器的分类 按计算能力分类 超级计算机 小型机AIX x86服务器(服务器cpu架构) …

Python连接redis

第一步安装redis Releases microsoftarchive/redis 安装时勾上所有能勾上的选项下一步即可 在CMD中pip install redis 安装redis pip install redis -i https://pypi.tuna.tsinghua.edu.cn/simple 配置redis 在redis安装目录下找到 修改 line 57 bind 0.0.0.0 line…

使用exceljs将excel文件转化为html预览最佳实践(完整源码)

前言 在企业应用中,我们时常会遇到需要上传并展示 Excel 文件的需求,以实现文件内容的在线预览。经过一番探索与尝试,笔者最终借助 exceljs 这一库成功实现了该功能。本文将以 Vue 3 为例,演示如何实现该功能,代码示例…

前端面经12 函数柯里化

<script>function sum(num){return function(num2){return numnum2}}console.log(sum(1)(2))</script>面试考察 只要参数够了 达到某个数量就输出 <script>let nums[]function sum(...args){nums.push(...args)if(nums.length>5){const out (nums.slice…

告别蜘蛛池!PHP 打造你的网站专属蜘蛛导航仪

在网站优化的赛道上&#xff0c;吸引搜索引擎蜘蛛来访一直是站长和开发者关注的重点。以往借助蜘蛛池、软件等工具引蜘蛛&#xff0c;不仅存在成本高、易违规的风险&#xff0c;效果也参差不齐。现在&#xff0c;有一种更高效、更安全的方式 —— 利用 PHP 代码&#xff0c;无需…

ubuntu kubeasz 部署高可用k8s 集群

ubuntu kubeasz 部署高可用k8s 集群 测试环境主机列表软件清单kubeasz 部署高可用 kubernetes配置源配置host文件安装 ansible 并进行 ssh 免密登录:下载 kubeasz 项⽬及组件部署集群部署各组件开始安装修改 config 配置文件增加 master 节点增加 kube_node 节点登录dashboard…

芯驰科技与安波福联合举办技术研讨会,深化智能汽车领域合作交流

5月15日&#xff0c;芯驰科技与全球移动出行技术解决方案供应商安波福&#xff08;Aptiv&#xff09;在上海联合举办以“芯智融合&#xff0c;共赢未来”为主题的技术研讨会。会上&#xff0c;双方聚焦智能座舱与智能车控的发展趋势&#xff0c;展开深入交流与探讨&#xff0c;…

【论文#目标检测】End-to-End Object Detection with Transformers

目录 摘要1.引言2.相关工作2.1 集合预测2.2 Transformer和并行解码2.3 目标检测 3.DETR模型3.1 目标检测集合预测损失3.2 DETR架构 4.实验4.1 与Faster R-CNN的比较4.2 消融研究4.3 分析4.4 DETR用于全景分割 5.结论6.致谢 Author: Nicolas Carion, Francisco Massa, Gabriel S…

Elasticsearch 深入分析三种分页查询【Elasticsearch 深度分页】

前言&#xff1a; 在前面的 Elasticsearch 系列文章中&#xff0c;分享了 Elasticsearch 的各种查询&#xff0c;分页查询也分享过&#xff0c;本篇将再次对 Elasticsearch 分页查询进行专题分析&#xff0c;“深度分页” 这个名词对于我们来说是一个非常常见的业务场景&#…

DAY29 超大力王爱学Python

知识点回顾 类的装饰器装饰器思想的进一步理解&#xff1a;外部修改、动态类方法的定义&#xff1a;内部定义和外部定义 作业&#xff1a;复习类和函数的知识点&#xff0c;写下自己过去29天的学习心得&#xff0c;如对函数和类的理解&#xff0c;对python这门工具的理解等&…

Ubuntu 远程桌面配置指南

概述: 本文主要介绍在Ubuntu 22.04中通过VNC实现远程连接的方法。首先需安装图形化界面和VNC工具x11vnc,设置开机启动服务;然后在Windows客户端用VNC Viewer通过局域网IP和端口5900连接。 总结: 一、VNC配置与安装 安装图形化界面 在Ubuntu 22.04中需先安装: sudo apt …

推扫式高光谱相机VIX-N230重磅发布——开启精准成像新时代

随着各行业对高光谱成像技术需求的持续增长&#xff0c;市场对于高分辨率、高灵敏度以及快速成像的高光谱相机的需求愈发迫切。中达瑞和凭借多年的行业经验和技术积累&#xff0c;敏锐捕捉到这一市场趋势&#xff0c;正式推出全新一代推扫式可见光近红外高光谱相机——VIX-N230…

Parsec解决PnP连接失败的问题

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、准备环境二、DMZ三、端口映射1.Parsec设置固定端口2.路由器设置端口转发3.重启被控端Parsec四、多少一句1.有光猫管理员账号2.没有光猫管理员账号总结 前言…

软件I2C

软件I2C 注意&#xff1a; SDA&#xff08;串行数据线&#xff09;和SCL&#xff08;串行时钟线&#xff09;都是双向I/O线&#xff0c;接口电路为开漏输出。需通过上拉电阻接电源VCC。 软件I2C说明 说明&#xff0c;有的单片机没有硬件I2C的功能&#xff0c;或者因为电路设计…

Brooks Polycold快速循环水蒸气冷冻泵客户使用手含电路图,适用于真空室应用

Brooks Polycold快速循环水蒸气冷冻泵客户使用手含电路图&#xff0c;适用于真空室应用