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