【mysql】ISNULL、NVL、IFNULL和COALESCE函数的使用方法

以下是 ISNULLNVLIFNULLCOALESCE 函数的详细使用方法:

1. ISNULL

SQL ServerSybase 使用 ISNULL 函数来处理空值。

语法

sql 复制代码
ISNULL(expression, replacement_value)

参数

  • expression:要检查的表达式。
  • replacement_value:如果 expression 为 NULL,则返回的值。

示例

sql 复制代码
-- SQL Server
SELECT ISNULL(NULL, 'Default Value') AS Result; -- 返回 'Default Value'
SELECT ISNULL((SELECT ColumnName FROM TableName WHERE Condition), 'Default Value') AS Result;

2. NVL

Oracle 使用 NVL 函数来处理空值。

语法

sql 复制代码
NVL(expression, replacement_value)

参数

  • expression:要检查的表达式。
  • replacement_value:如果 expression 为 NULL,则返回的值。

示例

sql 复制代码
-- Oracle
SELECT NVL(NULL, 'Default Value') FROM DUAL; -- 返回 'Default Value'
SELECT NVL((SELECT ColumnName FROM TableName WHERE Condition), 'Default Value') FROM DUAL;

3. IFNULL

MySQLMariaDB 使用 IFNULL 函数来处理空值。

语法

sql 复制代码
IFNULL(expression, replacement_value)

参数

  • expression:要检查的表达式。
  • replacement_value:如果 expression 为 NULL,则返回的值。

示例

sql 复制代码
-- MySQL
SELECT IFNULL(NULL, 'Default Value') AS Result; -- 返回 'Default Value'
SELECT IFNULL((SELECT ColumnName FROM TableName WHERE Condition), 'Default Value') AS Result;

4. COALESCE

SQL ServerPostgreSQLOracleMySQLMariaDB 等许多数据库系统都支持 COALESCE 函数。

语法

sql 复制代码
COALESCE(expression1, expression2, ...)

参数

  • expression1, expression2, ...:要检查的表达式列表。

返回值

  • 返回参数列表中第一个非 NULL 值。如果所有参数都是 NULL,则返回 NULL。

示例

sql 复制代码
-- SQL Server
select COALESCE (null,'100','120'); -- 返回 '100'

select COALESCE (null,'110',null,'120'); -- 返回 '110'

SELECT COALESCE(NULL, 'Second', 'Third') AS Result; -- 返回 'Second'
SELECT COALESCE((SELECT ColumnName1 FROM TableName WHERE Condition1), 'Second', 'Third') AS Result;

-- Oracle
SELECT COALESCE(NULL, 'Second', 'Third') FROM DUAL; -- 返回 'Second'
SELECT COALESCE((SELECT ColumnName1 FROM TableName WHERE Condition1), 'Second', 'Third') FROM DUAL;

-- MySQL
SELECT COALESCE(NULL, 'Second', 'Third') AS Result; -- 返回 'Second'
SELECT COALESCE((SELECT ColumnName1 FROM TableName WHERE Condition1), 'Second', 'Third') AS Result;

-- PostgreSQL
SELECT COALESCE(NULL, 'Second', 'Third') AS Result; -- 返回 'Second'
SELECT COALESCE((SELECT ColumnName1 FROM TableName WHERE Condition1), 'Second', 'Third') AS Result;

总结

  • ISNULL 用于 SQL ServerSybase
  • NVL 用于 Oracle
  • IFNULL 用于 MySQLMariaDB
  • COALESCE 用于 SQL ServerPostgreSQLOracleMySQLMariaDB

这些函数的主要目的是处理空值,确保查询结果的准确性和一致性。

相关推荐
花花无缺12 分钟前
MySQL--B+树
后端·mysql
khystal44 分钟前
HUMS 2023齿轮箱数据分析
数据库·数据分析·信号处理
Warren981 小时前
Spring Boot 整合网易163邮箱发送邮件实现找回密码功能
数据库·vue.js·spring boot·redis·后端·python·spring
追逐时光者1 小时前
推荐 4 个不错的数据库设计工具,效率提升利器!
数据库
似水流年流不尽思念2 小时前
mysql日志文件有哪些,分别介绍下作用 ?
后端·mysql·面试
.Shu.4 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【五、InnoDB 高阶机制与实战调优】
数据库·mysql
新法国菜5 小时前
MySql知识梳理之DDL语句
数据库·mysql
DarkAthena6 小时前
【GaussDB】全密态等值查询功能测试及全密态技术介绍
数据库·gaussdb
ShawnLeiLei6 小时前
2.3 Flink的核心概念解析
数据库·python·flink