【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

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

相关推荐
YaoYuan93231 分钟前
Ubuntu22.04 中搭建基于 Qemu 的内核(驱动)开发环境
数据库
hans汉斯3 分钟前
【计算机科学与应用】基于多光谱成像与边缘计算的物流安全风险预警模式及系统实现
大数据·数据库·人工智能·设计模式·机器人·边缘计算·论文笔记
叫我龙翔11 分钟前
【MySQL】从零开始了解数据库开发 --- 如何理解事务隔离性
数据库·mysql·数据库开发
你想考研啊34 分钟前
一、redis安装(单机)和使用
前端·数据库·redis
枫叶丹438 分钟前
【Qt开发】多元素类控件(三)-> QTreeWidget
开发语言·数据库·c++·qt
洲覆1 小时前
Redis 驱动适配 Reactor 模式
开发语言·网络·数据库·redis
IDOlaoluo1 小时前
win64_11gR2_client.zip 怎么安装?Oracle 11g 客户端详细安装步骤
数据库·oracle
呆呆小金人1 小时前
SQL入门:别名使用完全指南
大数据·数据库·数据仓库·sql·数据库开发·etl·etl工程师
缘友一世1 小时前
Redis未授权访问漏洞:从原理到高级利用
数据库·redis·缓存
码农阿豪3 小时前
国产化替代新篇章:金仓数据库如何实现MongoDB平滑迁移
数据库·mongodb