MySQL中NULLIF?、IFNULL、IF的用法和區(qū)別舉例詳解
前言
在 MySQL 中,NULLIF、IFNULL 和 IF 是用于處理 NULL 值的三種不同的函數(shù)。
1. NULLIF 函數(shù)
NULLIF 函數(shù)用于比較兩個表達式,如果它們的值相等,則返回 NULL,否則返回第一個表達式的值。語法如下:
NULLIF(expr1, expr2)
- expr1 和 expr2 是要比較的兩個表達式。
示例:
SELECT NULLIF(5, 5); -- 返回 NULL,因為兩個值相等 SELECT NULLIF(5, 10); -- 返回 5,因為兩個值不相等
2. IFNULL 函數(shù)
IFNULL 函數(shù)用于判斷第一個表達式是否為 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 函數(shù)
IF 函數(shù)用于根據(jù)一個條件返回兩個值中的一個。語法如下:
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. 區(qū)別總結(jié)
- NULLIF 用于比較兩個表達式,如果相等則返回 NULL。
- IFNULL 用于判斷一個表達式是否為 NULL,是則返回指定的默認(rèn)值。
- IF 用于根據(jù)條件返回兩個不同的值。
附:mysql函數(shù)IFNULL使用的注意事項
首先建一張簡單的表,用于sql語句的操作

建表語句如下:
CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主鍵' , `name` varchar(8) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '名字' , `score` int(4) NOT NULL DEFAULT 0 COMMENT '分?jǐn)?shù)' , PRIMARY KEY (`id`) );
手動創(chuàng)建數(shù)據(jù)如下:

現(xiàn)在開始正題:
a. IFNULL的作用是什么?下面一個簡單的sql和結(jié)果說明,如果IFNULL(a,b),a接收的值為null,則返回b,否則返回a;
SELECT IFNULL(NULL,0);

b. 以下sql語句,大家可以預(yù)測下結(jié)果,按照IFNULL函數(shù)的作用,應(yīng)該返回0才對,可是結(jié)果并不是這樣。
SELECT IFNULL(score,0) FROM student WHERE ID = 4;
返回結(jié)果,居然是null,與預(yù)期的結(jié)果0不一致。

c. 以下語句返回正確結(jié)果0;
SELECT IFNULL((SELECT score FROM student WHERE ID = 4),0);
總結(jié):使用b方式使用IFNULL、SUM函數(shù)等需要確保有查詢記錄,否則也將返回null值,當(dāng)然也可使用c方式避免返回null值,避免程序中出現(xiàn)NPE異常。
總結(jié)
到此這篇關(guān)于MySQL中NULLIF 、IFNULL、IF的用法和區(qū)別的文章就介紹到這了,更多相關(guān)MySQL NULLIF 、IFNULL、IF用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mysql中isnull,ifnull,nullif的用法及語義詳解
- MySQL中IF()、IFNULL()、NULLIF()、ISNULL()函數(shù)的用法解讀
- MySql中的IFNULL、NULLIF和ISNULL用法詳解
- MySQL流程控制IF()、IFNULL()、NULLIF()、ISNULL()函數(shù)的使用
- MySQL中IF()、IFNULL()、NULLIF()、ISNULL()函數(shù)的使用詳解
- mysql中null(IFNULL,COALESCE和NULLIF)相關(guān)知識點總結(jié)
- MySql中的IFNULL、NULLIF和ISNULL用法詳解
- MYSQL中IFNULL和NULLIF函數(shù)的區(qū)別小結(jié)
相關(guān)文章
MySQL數(shù)據(jù)庫中的UPDATE(更新數(shù)據(jù))詳解
這篇文章主要詳細(xì)介紹了MySQL的UPDATE語句,包括其基本語法、高級用法、性能優(yōu)化策略以及注意事項,通過示例和實戰(zhàn),幫助讀者更好地理解和應(yīng)用這一重要的SQL命令,需要的朋友可以參考下2024-12-12
MySQL數(shù)據(jù)表分區(qū)技術(shù)PARTITION詳解
在處理大規(guī)模數(shù)據(jù)時,數(shù)據(jù)庫性能的優(yōu)化變得尤為重要,MySQL提供了一種稱為“分區(qū)”(Partitioning)的技術(shù),可以顯著提高查詢效率和管理大型數(shù)據(jù)庫表的能力,本文將詳細(xì)介紹MySQL中的數(shù)據(jù)表分區(qū)技術(shù),包括其基本概念、類型以及如何實現(xiàn)和維護,需要的朋友可以參考下2025-02-02

