Mysql實現null值排在最前/最後的方法示例

這篇文章主要給大家介紹了關於Mysql實現null值排在最前/最後的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

我們已經知道 MySQL 使用 SQL SELECT 命令及 WHERE 子句來讀取數據表中的數據,但是當提供的查詢條件字段爲 NULL 時,該命令可能就無法正常工作。

爲了處理這種情況,MySQL提供了三大運算符:

  • IS NULL: 當列的值是 NULL,此運算符返回 true。
  • IS NOT NULL: 當列的值不爲 NULL, 運算符返回 true。
  • <=>: 比較操作符(不同於=運算符),當比較的的兩個值爲 NULL 時返回 true。

關於 NULL 的條件比較運算是比較特殊的。你不能使用 = NULL 或 != NULL 在列中查找 NULL 值 。

在 MySQL 中,NULL 值與任何其它值的比較(即使是 NULL)永遠返回 false,即 NULL = NULL 返回false 。

MySQL 中處理 NULL 使用 IS NULL 和 IS NOT NULL 運算符。

最近在做項目遷移,Oracle版本的遷到Mysql版本,遇到有些oracle的函數,mysql並沒有,所以就只好想自定義函數或者找到替換函數的方法進行改造。

oracle做數據排序的時候,有時候可以用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並沒有提供類似函數,所以要怎麼實現?

下面給出解決方法:

null值排在最後,用Mysql的IF和ISNULL函數。如果爲空返回1,否返回0

select * from A order by IF(ISNULL(a),1,0),a desc

null值排在最前,用Mysql的IF和ISNULL函數。如果爲空返回1,否返回0

select * from A order by IF(ISNULL(a),0,1),a desc

如果mybatis裏需要oracle和Mysql版本的,或者可以從後臺傳個數據表版本標識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>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章