【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

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

相关推荐
我最厉害。,。27 分钟前
Windows权限提升篇&数据库篇&MYSQL&MSSQL&ORACLE&自动化项目
数据库·mysql·sqlserver
远方160933 分钟前
20-Oracle 23 ai free Database Sharding-特性验证
数据库·人工智能·oracle
GoodStudyAndDayDayUp1 小时前
初入 python Django 框架总结
数据库·python·django
@大嘴巴子2 小时前
MySQL知识回顾总结----数据库基础
数据库·mysql
lubiii_2 小时前
SQL手工测试(MySQL数据库)
数据库·mysql·web安全·网络安全
凌辰揽月2 小时前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
想你依然心痛2 小时前
数据库入门:从原理到应用
数据库
20242817李臻4 小时前
20242817李臻-安全文件传输系统-项目验收
数据库·安全
行思理4 小时前
MongoDB慢查询临时开启方法讲解
数据库·mongodb
bbsh20994 小时前
WebFuture 升级提示“不能同时包含聚集KEY和大字段””的处理办法
数据库·sql·mysql·webfuture