MySQL關(guān)于字符串中數(shù)字排序的問題分析
本文實(shí)例講述了MySQL關(guān)于字符串中數(shù)字排序的問題。分享給大家供大家參考,具體如下:
MySQL字符串相信大家都不陌生,在MySQL字符串排序時(shí)經(jīng)常會(huì)遇到一些問題,比如下面要介紹的這個(gè)
今天解決了一個(gè)關(guān)于MySQL字符串排序的很奇怪的問題,在數(shù)據(jù)里面定義的是varchar類型,實(shí)際存放的是Int類型的數(shù)據(jù),按一下查詢語句進(jìn)行排序:
將字段*1或者+0可以將MySQL字符串字段按數(shù)值排序
如:
select * from table where 1 order by id*1 desc;
或者
select * from table where 1 order by id+0 desc;
除了上述方法外,這里附上一種排序方法,利用find_in_set()進(jìn)行無敵排序
附上Mysql函數(shù) find_in_set() 的用法:
FIND_IN_SET(str,strlist)
Returns a value 如果字符串 str 在由 N 個(gè)子串組成的列表 strlist 中,返回一個(gè) 1 到 N 的值。一個(gè)字符串列表是由通過字符 “,” 分隔的多個(gè)子串組成。如果第一個(gè)參數(shù)是一個(gè)常數(shù)字符串,并且第二個(gè)參數(shù)是一個(gè) SET 列類型,F(xiàn)IND_IN_SET() 函數(shù)將被優(yōu)化為使用位運(yùn)算!如果 str 在不 strlist 中或者如果 strlist 是一個(gè)空串,返回值為 0。如果任何一個(gè)參數(shù)為 NULL,返回值也是 NULL。如果第一個(gè)參數(shù)包含一個(gè) “,”,這個(gè)函數(shù)將完全不能工作:
mysql> SELECT FIND_IN_SET('b','a,b,c,d'); -> 2
for example:
大家有什么好的想法和建議可以留下寶貴的意見 以便共同進(jìn)步
更多關(guān)于MySQL相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《MySQL日志操作技巧大全》、《MySQL事務(wù)操作技巧匯總》、《MySQL存儲(chǔ)過程技巧大全》、《MySQL數(shù)據(jù)庫(kù)鎖相關(guān)技巧匯總》及《MySQL常用函數(shù)大匯總》
希望本文所述對(duì)大家MySQL數(shù)據(jù)庫(kù)計(jì)有所幫助。
相關(guān)文章
MySQL中的數(shù)據(jù)類型binary和varbinary詳解
binary和varbinary與char和varchar類型有點(diǎn)類似,不同的是binary和varbinary存儲(chǔ)的是二進(jìn)制的字符串,而非字符型字符串。下面這篇文章主要給大家介紹了關(guān)于MySQL中數(shù)據(jù)類型binary和varbinary的相關(guān)資料,介紹的非常詳細(xì),需要的朋友可以參考學(xué)習(xí)。2017-07-07mysql插入中文數(shù)據(jù)變成問號(hào)的解決方案
這篇文章主要介紹了mysql插入中文數(shù)據(jù)變成問號(hào)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04linux服務(wù)器清空MySQL的history歷史記錄 刪除mysql操作記錄
mysql歷史記錄上可能留下了很多敏感信息,比如密碼什么的,需及時(shí)清空歷史記錄,下面分享一下inux服務(wù)器清空MySQL的history歷史記錄的方法2014-01-01MySql 中聚合函數(shù)增加條件表達(dá)式的方法
這篇文章主要介紹了MySql 中聚合函數(shù)增加條件表達(dá)式的方法,需要的朋友可以參考下2018-06-06SQL?Server攜程核心系統(tǒng)無感遷移到MySQL實(shí)戰(zhàn)
這篇文章主要介紹了SQL?Server攜程核心系統(tǒng)無感遷移到MySQL實(shí)戰(zhàn),文章通過基于數(shù)據(jù)庫(kù)部署架構(gòu)鏡像構(gòu)建了訂單緩存統(tǒng)一管理熱點(diǎn)數(shù)據(jù),解決各端差異,具體詳情需要的小伙伴可以參考下面文章詳細(xì)內(nèi)容2022-05-05