Mysql的NULLIF

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 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月前
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 IS NULL
【8月更文挑战第12天】
633 0
在 MySQL 中使用 IS NULL
|
存储 SQL 算法
盘点一下Mysql中的一些小知识(三)
盘点一下Mysql中的一些小知识(三)
94 0
盘点一下Mysql中的一些小知识(三)
|
SQL 算法 关系型数据库
【MySQL】 MRR
【MySQL】 MRR
129 0
|
SQL 存储 缓存
|
存储 SQL Oracle
Mysql的前世今生,Hello,Mysql
1.什么是数据库? 数据库(Database)是按照数据结构来组织、存储和管理数据的仓库。 每个数据库都有一个或多个不同的 API 用于创建,访问,管理,搜索和复制所保存的数据。 我们也可以将数据存储在文件中,但是在文件中读写数据速度相对较慢。
117 0
Mysql的前世今生,Hello,Mysql
|
SQL 关系型数据库 MySQL
MySQL(五)
MySQL(五),一起来学习吧。
|
SQL 存储 安全
MySQL DEFINER详解
在 MySQL 数据库中,在创建视图及函数的时候,你有注意过 definer 选项吗?在迁移视图或函数后是否有过报错情况,这些其实都可能和 definer 有关系。本篇文章主要介绍下 MySQL 中 definer 的含义及作用。
1085 0
|
SQL 架构师 关系型数据库
MySQL三两奇巧
MySQL作为国内中小企业最流行的关系型数据库,在业务中经常会被用到。如果要说有什么奇巧,真的不是一两篇文章能够概述的 在这里挑选了一些在实际开发中可能会经常用到的一些技巧,简单地来说说。
|
关系型数据库 MySQL SQL