Mysql的NULLIF

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: Mysql的NULLIF


秉性难移。——冯梦龙

NULLIF函数是MySQL中的一个条件函数,用来返回两个表达式的比较结果。具体来说,如果两个表达式相等,NULLIF函数返回NULL;如果不相等,它就返回第一个表达式的值。其基本语法如下:

NULLIF(expr1, expr2)

其中,expr1expr2可以是任何类型的表达式,但它们应该是相同的数据类型或者可以隐式转换的类型。

在数学运算特别是除法运算中,除以零会导致错误。使用NULLIF可以有效避免这种错误。例如,我们要计算两个列AB的比值,可以这样写:

SELECT A, B, A / NULLIF(B, 0) AS result
FROM your_table;

这里,如果B为0,则NULLIF(B, 0)返回NULL,A / NULL也会返回NULL,从而避免了运行时错误。

在数据导入或处理过程中,我们可能会遇到一些特殊值需要转换为NULL以保持数据的一致性。例如,某些系统中使用-1表示数据缺失,我们可以使用NULLIF来转换这些值:

SELECT NULLIF(column_name, -1)
FROM your_table;

这样,所有为-1column_name值都会被转换为NULL。

在某些情况下,你可能需要在WHERE子句中排除一些特定的值。NULLIF可以在这里发挥作用,帮助简化查询逻辑。例如:

SELECT *
FROM your_table
WHERE NULLIF(column_name, 'Not Applicable') IS NOT NULL;

这个查询会排除所有column_name为’Not Applicable’的记录。

使用NULLIF函数将空字符串转换为NULL是一个简单直接的方法。基本语法如下:

SELECT NULLIF(column_name, '') AS new_column
FROM your_table;

这里的NULLIF(column_name, '')会检查column_name中的每个值,如果值是空字符串(“”),则该函数返回NULL;如果不是空字符串,就返回原值。这样,原本的空字符串就被视为了NULL值。

假设有一个用户信息表users,其中包含用户的邮箱地址email。在数据集中,未填写邮箱的用户被错误地存储为了空字符串。我们可以使用NULLIF来修正这一错误:

SELECT id, name, NULLIF(email, '') AS email
FROM users;

这个查询不仅修正了数据,还保持了原表的其他信息不变,使得整个数据集更加准确和有用。

除了基本的转换,NULLIF与其他SQL函数结合使用,可以实现更复杂的数据处理逻辑。比如,与COALESCE函数结合,可以实现多重默认值的逻辑:

SELECT COALESCE(NULLIF(email, ''), 'no-email@example.com') AS email
FROM users;

这个例子中,如果email是空字符串,则首先被NULLIF转换为NULL,然后COALESCE函数会将其替换为默认邮箱地址no-email@example.com,这样无论email''还是NULL,都会使用no-email@example.com

让我们通过一个实际的例子来看NULLIF的应用。假设一个电商数据库中有一个订单表,表中有coupon_discount字段,记录了使用优惠券的折扣金额,未使用优惠券的记录这一字段为0。我们可以用NULLIF来统计实际使用了优惠券的订单数量:

SELECT COUNT(*) 
FROM orders 
WHERE NULLIF(coupon_discount, 0) IS NOT NULL;

这条SQL语句统计了coupon_discount不为0的记录,即使用了优惠券的订单数。

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
关系型数据库 MySQL 数据库
在 MySQL 中使用 LIKE
【8月更文挑战第12天】
294 1
|
3月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 IS NULL
【8月更文挑战第12天】
639 0
在 MySQL 中使用 IS NULL
|
5月前
|
关系型数据库 MySQL Java
MySQL
【6月更文挑战第23天】
40 6
|
6月前
|
关系型数据库 MySQL AndFix
MySQL 8.0是MySQL
MySQL 8.0是MySQL发展的一个重要里程碑。在这个版本中,MySQL Server层的整体架构得到了质的飞跃,通过持续每三个月的迭代和重构工作,使得MySQL在性能和功能上都有了显著的提升。本文将基于MySQL 8.0.25源码,详细介绍MySQL 8.0的最新架构和一些重要的变化。
91 1
|
SQL 存储 缓存
|
SQL 搜索推荐 关系型数据库
MySQL的初步使用
引入 在之前的一篇文章中,我们一起过了一遍标准SQL语言的核心操作。标准sql语言适配市面上所有主流的RDBMS(即关系数据库管理系统 Relational DataBase Management System),你与任何一个RDBMS连接后,基本可以直接用所学命令进行操作了。
MySQL的初步使用
|
SQL 存储 数据可视化
|
SQL 关系型数据库 MySQL
Mysql 系列 一 explan
explan在数据库中的作用以及字段详解
|
SQL 存储 关系型数据库
MySQL8.0之快速加列
MySQL8.0 Online DDL
5009 2
|
关系型数据库 MySQL 数据库
mysql日常小报错
前言 今天安装好数据库发现show databases; 的时候没有权限 而且自己之前创建的数据库也看不到。 操作如下: general_log=1 log_output=TABLE mysql> SET GLOBAL general_log = 'OFF'; mysql> ALTER TABLE mysql.
698 0