本文實例講述了MySQL關于字符串中數字排序的問題。分享給大家供大家參考,具體如下:
MySQL字符串相信大家都不陌生,在MySQL字符串排序時經常會遇到一些問題,比如下面要介紹的這個
今天解決了一個關于MySQL字符串排序的很奇怪的問題,在數據里面定義的是varchar類型,實際存放的是Int類型的數據,按一下查詢語句進行排序:
將字段*1或者+0可以將MySQL字符串字段按數值排序
如:
1
|
select * from table where 1 order by id*1 desc ; |
或者
1
|
select * from table where 1 order by id+0 desc ; |
除了上述方法外,這里附上一種排序方法,利用find_in_set()進行無敵排序
附上Mysql函數 find_in_set() 的用法:
FIND_IN_SET(str,strlist)
Returns a value 如果字符串 str 在由 N 個子串組成的列表 strlist 中,返回一個 1 到 N 的值。一個字符串列表是由通過字符 “,” 分隔的多個子串組成。如果第一個參數是一個常數字符串,并且第二個參數是一個 SET 列類型,FIND_IN_SET() 函數將被優化為使用位運算!如果 str 在不 strlist 中或者如果 strlist 是一個空串,返回值為 0。如果任何一個參數為 NULL,返回值也是 NULL。如果第一個參數包含一個 “,”,這個函數將完全不能工作:
1
2
|
mysql> SELECT FIND_IN_SET( 'b' , 'a,b,c,d' ); -> 2 |
for example:
大家有什么好的想法和建議可以留下寶貴的意見 以便共同進步
希望本文所述對大家MySQL數據庫計有所幫助。