【MySQL】IF、ISNULL、IFNULL、NULLIF 的用法

news/2024/7/5 11:07:55

IF

含义:函数用于判断第一个表达式是否为 true,如果为 true 返回第二个参数,否则返回第三个参数

SELECT IF(2=2, 'a', 'b')
SELECT IF(1, 'a', 'b')
SELECT IF(2, 'a', 'b')
SELECT IF('2', 'a', 'b')

结果:a

SELECT IF(2!=2, 'a', 'b') 
SELECT IF(0, 'a', 'b') 
SELECT IF('', 'a', 'b') 
SELECT IF(null, 'a', 'b') 

结果:b

结论:函数中第一个参数为 false,0,空字符串,null 都返回第三个参数,否则返回第二个参数

ISNULL

含义:判断是否为 null,如果为 null 则返回 1,否则返回 0

SELECT ISNULL(0)
SELECT ISNULL('') 

结果:0

SELECT ISNULL(null)

结果:1

结论:MySQL不会将 0 和 空字符串 判断为空,比较严谨,只会将真实的 null 判断为空

IFNULL

含义:函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,否则返回第一个参数的值

SELECT IFNULL('', '空的') 

结果:空字符串,无显示

SELECT IFNULL(0, '空的') 

结果:0

SELECT IFNULL(null, '空的')

结果:空的

结论:当第一个参数是 null 时,才会返回第二个参数,否则直接返回第一个参数

NULLIF

含义:如果第二个参数等于第一个参数则返回 null ,否则返回第一个参数

SELECT NULLIF('', '') 
SELECT NULLIF(null, null) 
SELECT NULLIF(1, 1)

结果:(Null)

SELECT NULLIF('', null)

结果:空字符串,无显示

SELECT NULLIF(1, 2)

结果:1

结论:当第一个参数和第二个参数相等时,才返回 null ,否则直接返回第一个参数

参考

MySQL 中 ISNULL, IFNULL, NULLIF 的区别


http://lihuaxi.xjx100.cn/news/1803277.html

相关文章

lvgl 画圆弧时进入 HardFault

目录 一、现象描述 lvgl 版本 二、问题分析 lvgl 需要的资源新建mcu 工程时默认分配的资源问题解决 一、现象描述 移植完lvgl 之后,能正常显示label,但是button arc 等复杂的控件都不能正常显示。调用官方的画圆弧demo 时,在多次调用 _lv…

集软件库、论坛、社区、工具箱、积分商城、会员体系、在线商城一体的后台系统+HBuilderX 前端软件社区

集软件库、论坛、社区、工具箱、积分商城、会员体系、在线商城等多个功能于一体的全面后台系统加上强大的HBuilderX前端软件社区,为用户提供了全面的应用开发和交流平台 企业猫提供了完善的后台搭建服务,通过该服务,用户可以方便地搭建出所需…

LrC ACR :优化的 AI 天空蒙版

在 Lightroom Classic 和 Adobe Camera Raw 中创建基于 AI 技术的天空蒙版时,可能由于底层算法的原因,选中的天空蒙版在边缘处有晕开的现象(又称为“出血” Bleed),从而导致天空蒙版不是很精准。 本文提供了一种特殊方…

Beego之Bee工具使用

1、bee工具使用 bee 工具是一个为了协助快速开发 Beego 项目而创建的项目,通过 bee 你可以很容易的进行 Beego 项目的创 建、热编译、开发、测试、和部署。Bee工具可以使用的命令: [rootzsx ~]# bee 2023/02/18 18:17:26.196 [D] init global config…

PowerShell安装scoop和oh-my-posh

一、安装PowerShell 1、Github下载地址 GitHub - PowerShell/PowerShell: PowerShell for every system! 建议下载TLS或者stable版本 2、查看PowerShell版本 输入 $PSVersionTable.PSVersion 命令 PS C:\Program Files\PowerShell\7> $PSVersionTable.PSVersion Major M…

Gdevops北京站 2023年全球敏捷运维峰会-核心PPT资料下载

一、峰会简介 2023 Gdevops全球敏捷运维峰会-北京站成功举办,一众产学研界技术大佬与新锐专家,以智能为主线,就数据库、运维、架构、金融科技等领域进行了前沿技术与实践经验交流,一同畅聊AIGC、云原生、数智化转型下的新机遇。 …

花 200 元测试 1300 个实时数据同步任务

背景 对于将数据作为重要生产资料的公司来说,超大规模的数据迁移同步系统( 1k、5k、10k 条同步任务)是刚需。 本文以此为出发点,介绍近期 CloudCanal 所做的一个容量测试:在单个 CloudCanal 集群上创建 1300 实时任务,验证系统是…

现有文章汇总

Cotent 项目开发FreeRTOS/ESP-IDFSTM32C/C 数据结构数据库Python基础Python实例PyQt5/Pyside2 上位机开发FlaskLinux运维树莓派4BCH552ESP32实例计算机网络Javaeclipsemicropython日常问题解决 项目开发 基于树莓派4B的车牌号识别 FreeRTOS/ESP-IDF Ubuntu下ESP-IDF的环境搭…