MySQL中NULLIF?、IFNULL、IF的用法和區(qū)別舉例詳解
前言
在 MySQL 中,NULLIF、IFNULL 和 IF 是用于處理 NULL 值的三種不同的函數(shù)。
1. NULLIF 函數(shù)
NULLIF 函數(shù)用于比較兩個(gè)表達(dá)式,如果它們的值相等,則返回 NULL,否則返回第一個(gè)表達(dá)式的值。語(yǔ)法如下:
NULLIF(expr1, expr2)
- expr1 和 expr2 是要比較的兩個(gè)表達(dá)式。
示例:
SELECT NULLIF(5, 5); -- 返回 NULL,因?yàn)閮蓚€(gè)值相等 SELECT NULLIF(5, 10); -- 返回 5,因?yàn)閮蓚€(gè)值不相等
2. IFNULL 函數(shù)
IFNULL 函數(shù)用于判斷第一個(gè)表達(dá)式是否為 NULL,如果是,則返回第二個(gè)表達(dá)式的值;否則,返回第一個(gè)表達(dá)式的值。語(yǔ)法如下:
IFNULL(expr1, expr2)
- expr1 是要判斷是否為 NULL 的表達(dá)式。
- expr2 是如果 expr1 為 NULL 時(shí)返回的值。
示例:
SELECT IFNULL(NULL, 'default_value'); -- 返回 'default_value',因?yàn)榈谝粋€(gè)表達(dá)式為 NULL SELECT IFNULL('not_null_value', 'default_value'); -- 返回 'not_null_value',因?yàn)榈谝粋€(gè)表達(dá)式不為 NULL
3. IF 函數(shù)
IF 函數(shù)用于根據(jù)一個(gè)條件返回兩個(gè)值中的一個(gè)。語(yǔ)法如下:
sqlIF(condition, value_if_true, value_if_false)
- condition 是一個(gè)條件表達(dá)式。
- value_if_true 是如果條件為真時(shí)返回的值。
- value_if_false 是如果條件為假時(shí)返回的值。
示例:
SELECT IF(5 > 3, 'true_value', 'false_value'); -- 返回 'true_value',因?yàn)闂l件為真 SELECT IF(5 < 3, 'true_value', 'false_value'); -- 返回 'false_value',因?yàn)闂l件為假
4. 區(qū)別總結(jié)
- NULLIF 用于比較兩個(gè)表達(dá)式,如果相等則返回 NULL。
- IFNULL 用于判斷一個(gè)表達(dá)式是否為 NULL,是則返回指定的默認(rèn)值。
- IF 用于根據(jù)條件返回兩個(gè)不同的值。
附:mysql函數(shù)IFNULL使用的注意事項(xiàng)
首先建一張簡(jiǎn)單的表,用于sql語(yǔ)句的操作
建表語(yǔ)句如下:
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`) );
手動(dòng)創(chuàng)建數(shù)據(jù)如下:
現(xiàn)在開(kāi)始正題:
a. IFNULL的作用是什么?下面一個(gè)簡(jiǎn)單的sql和結(jié)果說(shuō)明,如果IFNULL(a,b),a接收的值為null,則返回b,否則返回a;
SELECT IFNULL(NULL,0);
b. 以下sql語(yǔ)句,大家可以預(yù)測(cè)下結(jié)果,按照IFNULL函數(shù)的作用,應(yīng)該返回0才對(duì),可是結(jié)果并不是這樣。
SELECT IFNULL(score,0) FROM student WHERE ID = 4;
返回結(jié)果,居然是null,與預(yù)期的結(jié)果0不一致。
c. 以下語(yǔ)句返回正確結(jié)果0;
SELECT IFNULL((SELECT score FROM student WHERE ID = 4),0);
總結(jié):使用b方式使用IFNULL、SUM函數(shù)等需要確保有查詢(xún)記錄,否則也將返回null值,當(dāng)然也可使用c方式避免返回null值,避免程序中出現(xiàn)NPE異常。
總結(jié)
到此這篇關(guān)于MySQL中NULLIF 、IFNULL、IF的用法和區(qū)別的文章就介紹到這了,更多相關(guān)MySQL NULLIF 、IFNULL、IF用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL中空值和NULL的區(qū)別小結(jié)
- MySQL默認(rèn)值(DEFAULT)和非空約束(NOT NULL)的實(shí)現(xiàn)
- MySQL語(yǔ)句之條件語(yǔ)句IFNULL和COALESCE的區(qū)別說(shuō)明
- MySQL中的case?when中對(duì)于NULL值判斷的坑及解決
- mysql ifnull不起作用原因分析以及解決
- 檢查MySQL中的列是否為空或Null的常用方法
- mysql?count()函數(shù)不計(jì)算null和空值問(wèn)題
- mysql的case when字段為空,null的問(wèn)題
- mysql?count?為null時(shí),顯示0的問(wèn)題
- MySQL?5.7中NULL與‘?‘空字符值的多維度分析(詳解)
相關(guān)文章
Mysql5.7.14安裝配置方法操作圖文教程(密碼問(wèn)題解決辦法)
本篇文章主要涉及mysql5.7.14用以往的安裝方法安裝存在的密碼登錄不上,密碼失效等問(wèn)題的解決辦法,需要的朋友參考下吧2017-01-01MySQL數(shù)據(jù)遷移相關(guān)總結(jié)
這篇文章主要介紹了MySQL數(shù)據(jù)遷移的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用MySQL數(shù)據(jù)庫(kù),感興趣的朋友可以了解下2021-04-04navicat連接mysql時(shí)出現(xiàn)1045錯(cuò)誤的解決方法
這篇文章主要為大家詳細(xì)介紹了navicat連接mysql時(shí)出現(xiàn)1045錯(cuò)誤的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02MySQL中IF語(yǔ)句的基礎(chǔ)及進(jìn)階用法
在Mysql數(shù)據(jù)庫(kù)中實(shí)現(xiàn)判斷功能有很多方式,具體又分為函數(shù)和if語(yǔ)句形式,下面這篇文章主要給大家介紹了關(guān)于MySQL中IF語(yǔ)句的基礎(chǔ)及進(jìn)階用法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01mysql如何增加數(shù)據(jù)表的字段(ALTER)
這篇文章主要介紹了mysql如何增加數(shù)據(jù)表的字段(ALTER),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11MYSQL代碼 定期備份Mysql數(shù)據(jù)庫(kù)
Mysql自動(dòng)備份腳本供大家參考,實(shí)現(xiàn)了定期備份Mysql數(shù)據(jù)庫(kù),并且可以選在在每周的一天做指定目錄下文件的全面?zhèn)浞荩瑐浞菸募詣?dòng)上傳到你指定的FTP上,保證了備份的可靠性。2009-04-04MySQL ORDER BY 的實(shí)現(xiàn)分析
總的來(lái)說(shuō),在 MySQL 中的ORDER BY有兩種排序?qū)崿F(xiàn)方式,一種是利用有序索引獲取有序數(shù)據(jù),另一種則是通過(guò)相應(yīng)的排序算法,將取得的數(shù)據(jù)在內(nèi)存中進(jìn)行排序2012-07-07SQL優(yōu)化老出錯(cuò),那是你沒(méi)弄明白MySQL解釋計(jì)劃用法
本篇文章講的是SQL優(yōu)化老出錯(cuò),那是你沒(méi)弄明白MySQL解釋計(jì)劃用法,有興趣的小伙伴速度來(lái)看看吧,希望本篇文章能夠幫助到你2021-11-11