MySQL 中 NULLIF 、IFNULL、IF 的用法和区别

在 MySQL 中,NULLIF、IFNULL 和 IF 是用于处理 NULL 值的三种不同的函数。

1. NULLIF 函数

NULLIF 函数用于比较两个表达式,如果它们的值相等,则返回 NULL,否则返回第一个表达式的值。语法如下:

NULLIF(expr1, expr2)
  • expr1 和 expr2 是要比较的两个表达式。

示例:

SELECT NULLIF(5, 5); -- 返回 NULL,因为两个值相等
SELECT NULLIF(5, 10); -- 返回 5,因为两个值不相等

2. IFNULL 函数

IFNULL 函数用于判断第一个表达式是否为 NULL,如果是,则返回第二个表达式的值;否则,返回第一个表达式的值。语法如下:

IFNULL(expr1, expr2)
  • expr1 是要判断是否为 NULL 的表达式。
  • expr2 是如果 expr1 为 NULL 时返回的值。

示例:

SELECT IFNULL(NULL, 'default_value'); -- 返回 'default_value',因为第一个表达式为 NULL
SELECT IFNULL('not_null_value', 'default_value'); -- 返回 'not_null_value',因为第一个表达式不为 NULL

3. IF 函数

IF 函数用于根据一个条件返回两个值中的一个。语法如下:

sqlIF(condition, value_if_true, value_if_false)
  • condition 是一个条件表达式。
  • value_if_true 是如果条件为真时返回的值。
  • value_if_false 是如果条件为假时返回的值。

示例:

SELECT IF(5 > 3, 'true_value', 'false_value'); -- 返回 'true_value',因为条件为真
SELECT IF(5 < 3, 'true_value', 'false_value'); -- 返回 'false_value',因为条件为假

4. 区别总结

  • NULLIF 用于比较两个表达式,如果相等则返回 NULL。
  • IFNULL 用于判断一个表达式是否为 NULL,是则返回指定的默认值。
  • IF 用于根据条件返回两个不同的值。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/351592.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

32和64位jvm_我应该使用32位还是64位JVM?

32和64位jvm这是我在企业软件开发生涯中多次遇到的问题。 我不得不每隔一段时间就提供有关配置特定新环境的建议。 而且&#xff0c;很多时候&#xff0c;手头的问题与“我应该使用32位或64位JVM”有关。 老实说&#xff0c;一开始我只是掷硬币。 而不是给出合理的答案。 &…

spring java code配置_Spring-09-使用Java的方式配置Spring

9. 使用Java的方式配置Spring我们现在要完全不使用Spring的xml配置&#xff0c;全权使用Java来配置Spring&#xff01;JavaConfig是Spring的一个子项目&#xff0c;在Spring4之后&#xff0c;他成为了一个核心功能。实体类&#xff1a;public class User {private String name;…

pythone函数基础(11)读,写,修改EXCEL

#读EXCEL需要导入xlrd模块---在python控制台pip install xlrd模块import xlrdbook xlrd.open_workbook(stu3.xls)sheet book.sheet_by_index(0)# sheet book.sheet_by_name(sheet1)# print(sheet.cell(0,0).value)#获取指定单元格的内容# print(sheet.cell(1,0).value)# pri…

强大的vim配置文件,让编程更随意

花了很长时间整理的&#xff0c;感觉用起来很方便&#xff0c;共享一下。 我的vim配置主要有以下优点&#xff1a; 1.按F5可以直接编译并执行C、C、java代码以及执行shell脚本&#xff0c;按“F8”可进行C、C代码的调试 2.自动插入文件头 &#xff0c;新建C、C源文件时自动插…

java工程转maven工程_将java工程转换为Maven工程

1、创建一个Java工程&#xff0c;如下图所示&#xff1a;2、选中此工程 -> 右键 -> Configure -> Convert to Maven project。出现如下的截图&#xff1a;3、点击之后会弹出对话框&#xff0c;如下图所示&#xff1a;4、直接点击完成即可&#xff0c;此时会在java工程…

2019/4/17 Linux学习

一、Linux的文件系统 其中/prov、/srv、/sys 文件为文件系统&#xff0c;技术不过硬不要去修改&#xff1b;二、关于Xshell、Xft1、服务器的端口可有65535个可设置&#xff0c;开的越多安全性越差&#xff1b;2、远程登录主机时&#xff0c;会有一个sshd程序&#xff0c;22端口…

使用“另类” Cloud Foundry Gradle插件无需停机

我一直在尝试我的手在写一个gradle这个插件的应用程序部署到Cloud Foundry上 &#xff0c;并写下这个插件在我以前的帖子 。 我现在通过使用两种方法支持将无停机时间部署到Cloud Foundry中来增强此插件&#xff1a; 自动驾驶风格部署和更常用的蓝绿色风格部署 。 要完全了解该…

UNIX网络编程 卷2 源代码使用

1. 下载源码&#xff0c;W. Richard Stevens的主页&#xff1a;http://www.kohala.com/start/wget http://www.kohala.com/start/unpv22e/unpv22e.tar.gz -P /usr/local/src 2. 解压tar xvf /usr/local/src/unpv22e.tar.gz -C /root/bin 3. 编译库文件cd /root/bin/unpv22e/ .…

语言工程中有趣的事情

如果您阅读此博客&#xff0c;您将知道我坚信语言的力量。 因此&#xff0c;我当然有很大的偏见&#xff0c;但是我感觉语言工程社区正在增长&#xff0c;并且越来越有趣的东西正在涌现。 为此&#xff0c;我认为通过查看社区中正在发生的事情并列出一些我发现有趣的事情来结束…

操作 实例 / dom

响应式&#xff1a;数据改变时会触发其他联动。例如&#xff1a;模板中的数据绑定&#xff1b;计算属性的重新计算&#xff1b;———————————————————————————————————————————————————— vm.$parent $parent 属性可以用来从…

sql注入程序_Java应用程序中SQL注入

sql注入程序在本文中&#xff0c;我们将讨论什么是SQL注入攻击。 以及它如何影响任何Web应用程序使用后端数据库。 在这里&#xff0c;我专注于Java Web应用程序。 开放Web应用程序安全性项目&#xff08;OWAP&#xff09;列出了SQL注入是Web应用程序的主要漏洞攻击。 黑客将We…

C++设计模式-Prototype原型模式

作用&#xff1a; 用原型实例指定创建对象的种类&#xff0c;并且通过拷贝这些原型创建新的对象。 Prototype模式提供了一个通过已存在对象进行新对象创建的接口&#xff08;Clone&#xff09;&#xff0c; Clone()实现和具体的语言相关&#xff0c;在C中通过拷贝构造函数实现。…

[SHOI2008]cactus仙人掌图

Description 如果某个无向连通图的任意一条边至多只出现在一条简单回路&#xff08;simple cycle&#xff09;里&#xff0c;我们就称这张图为仙人掌图&#xff08;cactus&#xff09;。所谓简单回路就是指在图上不重复经过任何一个顶点的回路。 举例来说&#xff0c;上面的第一…

java 导入导出txt文件_Java读取和写入txt文件

1 问题描述对于java的读取和写入txt一直心存疑惑&#xff0c;随着知识的积累&#xff0c;又重新进行学习&#xff0c;对java的文件读写理解更加深刻&#xff0c;在这里将自己的小小经验总结分享给大家。下面是大家了解java流的一个基本框架。2 问题分析在java中&#xff0c;jav…

[国家集训队] tree Ⅱ

bzoj2631&#xff08;权限题。。。&#xff09;:链接 落咕:链接 考察的是LCT维护链上信息。 但是这个题不一样的是又有加法又有乘法。。。&#xff08;有木有想到落咕的模板——线段树2qwq&#xff09; 因为乘法的运算优先度比加法高&#xff0c;所以我们要先做乘法再做加法&am…

C++拷贝构造函数(深拷贝,浅拷贝)

对于普通类型的对象来说&#xff0c;它们之间的复制是很简单的&#xff0c;例如&#xff1a; int a88; int ba; 而类对象与普通对象不同&#xff0c;类对象内部结构一般较为复杂&#xff0c;存在各种成员变量。下面看一个类对象拷贝的简单例子。 #include <iostream>u…

java用for循环修改密码_Java for循环的几种用法分析

J2SE 1.5提供了另一种形式的for循环。借助这种形式的for循环&#xff0c;可以用更简单地方式来遍历数组和Collection等类型的对象。本文介绍使用这种循环的具体方式&#xff0c;说明如何自行定义能被这样遍历的类&#xff0c;并解释和这一机制的一些常见问题。在Java程序中&…

apache camel_Apache Camel入门

apache camel在先前的博文中&#xff0c;我们了解了企业集成模式&#xff08;EIP&#xff09;。 现在&#xff0c;在这篇文章中&#xff0c;我们将研究实现这些模式的Apache Camel框架。 关于骆驼&#xff1a; Apache Camel是一个开放源代码项目&#xff0c;已有将近5年的历史…

C++拷贝构造函数详解

一. 什么是拷贝构造函数 首先对于普通类型的对象来说&#xff0c;它们之间的复制是很简单的&#xff0c;例如&#xff1a; [c-sharp] view plaincopyint a 100; int b a; 而类对象与普通对象不同&#xff0c;类对象内部结构一般较为复杂&#xff0c;存在各种成员变量。 …

mysql经典总结文章_MySQL基础篇(01):经典实用查询案例,总结整理

一、连接查询图解示意图1、建表语句部门和员工关系表&#xff1a;CREATE TABLE tb_dept (id int(11) NOT NULL AUTO_INCREMENT COMMENT 主键ID,deptName varchar(30) DEFAULT NULL COMMENT 部门名称,PRIMARY KEY (id)) ENGINEInnoDB AUTO_INCREMENT6 DEFAULT CHARSETutf8;CREAT…