MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的方法
前言
order by排序是最常用的功能,但是排序有時會遇到數(shù)據(jù)為空null的情況,這樣排序就會亂了,這里以MySQL為例,記錄我遇到的問題和解決思路。
sql 排序為 null 值問題:
排序時我們用 receive_date(一個統(tǒng)計的時間,里面有較多的null) 排序,那么在倒序時因為 receive_date 的值 有null的 所以會排在最前面,有值的排在后面。
order by managerapply.receive_date desc, mi.item_code
這樣order by時,為null的數(shù)據(jù)就會排在最前邊。
解決辦法:
法一:加負號
最優(yōu)辦法:利用MySQL中的一個小技巧,在字段前面加上一個負號,也就是減號,ASC改成DESC ,DESC改成ASC
order by -managerapply.receive_date asc, mi.item_code
好家伙,忘記時間加負號那是啥?所以該方法不可以取,針對字符類或者數(shù)值類的可以吧。如age?
法二:排序字段加 is null
我們可以在排序添加加上 is null 這個在加排序條件 空值就會排在后面,其他正常排序
order by managerapply.receive_date is null, managerapply.receive_date desc, mi.item_code
法三:新增一列排序字段的null值映射
如:重新給age生成一列,比如receive_datenull,利用is null操作符,把NULL值的行變成1,非NULL值的行變成0,先對該字段排序,再對age排序(這種方法第二種方法的解讀,明白is null的用法和原理?。。。?/p>
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方法:
# 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é)
到此這篇關(guān)于MySQL中order by排序時數(shù)據(jù)存在null則排序在最前面的方法的文章就介紹到這了,更多相關(guān)MySQL order by排序null排最前面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
防止服務(wù)器宕機時MySQL數(shù)據(jù)丟失的幾種方案
這篇文章主要介紹了防止服務(wù)器宕機時MySQL數(shù)據(jù)丟失的幾種方案,結(jié)合實踐介紹了Replication和Monitor以及Failover這三個項目的應(yīng)用,需要的朋友可以參考下2015-06-06MySQL數(shù)據(jù)庫中遇到no?database?selected問題解決辦法
這篇文章主要給大家介紹了關(guān)于MySQL數(shù)據(jù)庫中遇到no?database?selected問題的解決辦法,這是MySQL數(shù)據(jù)庫的錯誤提示,意思是沒有選擇數(shù)據(jù)庫,在使用MySQL命令行操作時需要先選擇要操作的數(shù)據(jù)庫,否則就會出現(xiàn)這個錯誤,需要的朋友可以參考下2024-03-03MySQL中slave_exec_mode參數(shù)詳解
本篇文章主要給大家講述了MySQL中slave_exec_mode參數(shù)的用法以及示例分析了出現(xiàn)的錯誤問題和解決辦法,需要的朋友參考學(xué)習(xí)下吧。2017-12-12mysql運行net start mysql報服務(wù)名無效的解決辦法
這篇文章主要為大家詳細介紹了mysql運行net start mysql報服務(wù)名無效的解決辦法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01