前言
我們已經(jīng)知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句來讀取數(shù)據(jù)表中的數(shù)據(jù),但是當(dāng)提供的查詢條件字段為 NULL 時,該命令可能就無法正常工作。
為了處理這種情況,MySQL提供了三大運算符:
- IS NULL: 當(dāng)列的值是 NULL,此運算符返回 true。
- IS NOT NULL: 當(dāng)列的值不為 NULL, 運算符返回 true。
- =>: 比較操作符(不同于=運算符),當(dāng)比較的的兩個值為 NULL 時返回 true。
關(guān)于 NULL 的條件比較運算是比較特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。
在 MySQL 中,NULL 值與任何其它值的比較(即使是 NULL)永遠(yuǎn)返回 false,即 NULL = NULL 返回false 。
MySQL 中處理 NULL 使用 IS NULL 和 IS NOT NULL 運算符。
最近在做項目遷移,Oracle版本的遷到Mysql版本,遇到有些oracle的函數(shù),mysql并沒有,所以就只好想自定義函數(shù)或者找到替換函數(shù)的方法進(jìn)行改造。
oracle做數(shù)據(jù)排序的時候,有時候可以用nulls first或者nulls last將null值排在最前或者最后。
oracle方法:
null值排在最前
select * from A order by a desc null first
null值排在最后
select * from A order by a desc null last
不過遷到Mysql的話,mysql并沒有提供類似函數(shù),所以要怎么實現(xiàn)?
下面給出解決方法:
null值排在最后,用Mysql的IF和ISNULL函數(shù)。如果為空返回1,否返回0
select * from A order by IF(ISNULL(a),1,0),a desc
null值排在最前,用Mysql的IF和ISNULL函數(shù)。如果為空返回1,否返回0
select * from A order by IF(ISNULL(a),0,1),a desc
如果mybatis里需要oracle和Mysql版本的,或者可以從后臺傳個數(shù)據(jù)表版本標(biāo)識dbType,或者直接用mybatis的_databaseId方法。
if test="dbType=='oracle'">
order by c.create_date desc nulls last
/if>
if test="dbType=='mysql'">
order by IF(ISNULL(c.create_date),1,0), c.create_date desc
/if>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
您可能感興趣的文章:- 你知道m(xù)ysql中空值和null值的區(qū)別嗎
- 解決mysql使用not in 包含null值的問題
- MySQL Innodb 存儲結(jié)構(gòu) 和 存儲Null值 用法詳解
- mysql字符串拼接并設(shè)置null值的實例方法
- MySQL中對于NULL值的理解和使用教程
- 詳解MySQL中的NULL值
- mysql中將null值轉(zhuǎn)換為0的語句
- MySQL中關(guān)于null值的一個小問題