【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

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

相关推荐
AllData公司负责人30 分钟前
【亲测好用】云原生数据平台能力演示
数据库·云原生·开源
VX:Fegn08958 小时前
计算机毕业设计|基于ssm + vue超市管理系统(源码+数据库+文档)
前端·数据库·vue.js·spring boot·后端·课程设计
chipsense8 小时前
电流传感器型号从数据库查询并排序输出到网页的方法
数据库·php·传感器·霍尔电流传感器
踢足球09298 小时前
寒假打卡:2026-01-28
数据库·oracle
麦聪聊数据8 小时前
智慧医疗数据互联互通:使用 QuickAPI 构建实时诊疗数据交换层
数据库·sql·安全
风吹落叶花飘荡8 小时前
2026年mysql数据库迁移(全流程)
数据库·mysql
2301_822382768 小时前
Python上下文管理器(with语句)的原理与实践
jvm·数据库·python
m0_748229998 小时前
Laravel8.X核心功能全解析
开发语言·数据库·php
液态不合群9 小时前
【面试题】MySQL 的索引下推是什么?
数据库·mysql
2301_790300969 小时前
Python深度学习入门:TensorFlow 2.0/Keras实战
jvm·数据库·python