亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的方法

 更新時間:2024年06月28日 09:27:57   作者:李仙桎  
order by排序是最常用的功能,但是排序有時會遇到數(shù)據(jù)為空null的情況,這樣排序就會亂了,這篇文章主要給大家介紹了關(guān)于MySQL中order?by排序時數(shù)據(jù)存在null則排序在最前面的相關(guān)資料,需要的朋友可以參考下

前言

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)文章

  • MySQL聯(lián)合索引用法示例

    MySQL聯(lián)合索引用法示例

    這篇文章主要介紹了MySQL聯(lián)合索引用法,結(jié)合實例形式分析了MySQL聯(lián)合索引的具體定義與使用方法,需要的朋友可以參考下
    2016-09-09
  • MySQL批量去掉某個字段中的空格

    MySQL批量去掉某個字段中的空格

    這篇文章主要介紹了MySQL批量去掉某個字段中的空格的簡單方法,具有一定參考價值,給大家分享下,一起參考,交流。
    2017-10-10
  • 防止服務(wù)器宕機時MySQL數(shù)據(jù)丟失的幾種方案

    防止服務(wù)器宕機時MySQL數(shù)據(jù)丟失的幾種方案

    這篇文章主要介紹了防止服務(wù)器宕機時MySQL數(shù)據(jù)丟失的幾種方案,結(jié)合實踐介紹了Replication和Monitor以及Failover這三個項目的應(yīng)用,需要的朋友可以參考下
    2015-06-06
  • MySQL中的主鍵自增機制詳情

    MySQL中的主鍵自增機制詳情

    這篇文章主要介紹了MySQL中的主鍵自增機制詳情,MySQL提供了主鍵自增機制AUTO_INCREMENT.?對主鍵使用,?保證了主鍵的唯一性,下文詳細介紹需要的小伙伴可以參考一下
    2022-08-08
  • MySQL數(shù)據(jù)庫中遇到no?database?selected問題解決辦法

    MySQL數(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-03
  • MySQL批量更新的四種方式總結(jié)

    MySQL批量更新的四種方式總結(jié)

    最近需要批量更新大量數(shù)據(jù),習(xí)慣了寫sql,所以還是用sql來實現(xiàn),下面這篇文章主要給大家總結(jié)介紹了關(guān)于MySQL批量更新的四種方式,需要的朋友可以參考下
    2023-01-01
  • 詳解mysql三值邏輯與NULL

    詳解mysql三值邏輯與NULL

    這篇文章主要介紹了mysql三值邏輯和NULL,感興趣的同學(xué)們,可以參考下,并且把代碼實驗一下
    2021-05-05
  • MySQL中slave_exec_mode參數(shù)詳解

    MySQL中slave_exec_mode參數(shù)詳解

    本篇文章主要給大家講述了MySQL中slave_exec_mode參數(shù)的用法以及示例分析了出現(xiàn)的錯誤問題和解決辦法,需要的朋友參考學(xué)習(xí)下吧。
    2017-12-12
  • MySQL半同步復(fù)制原理配置與介紹詳解

    MySQL半同步復(fù)制原理配置與介紹詳解

    這篇文章主要介紹了MySQL半同步復(fù)制原理配置與介紹詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • mysql運行net start mysql報服務(wù)名無效的解決辦法

    mysql運行net start mysql報服務(wù)名無效的解決辦法

    這篇文章主要為大家詳細介紹了mysql運行net start mysql報服務(wù)名無效的解決辦法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01

最新評論