MySQL字串中數字排序的問題

來源:互聯網
上載者:User

MySQL字串相信大家都不陌生,在MySQL字串排序時經常會遇到一些問題,比如下面的這個:

今天解決了一個關於MySQL字串排序的很奇怪的問題,在資料裡面定義的是varchar類型,實際存放的是Int類型的資料,按一下查詢語句進行排序:

將欄位*1或者+0可以將MySQL字串欄位按數值排序
如:

select * from table where 1   order by id*1 desc;  

或者

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。如果第一個參數包含一個 “,”,這個函數將完全不能工作:

mysql> SELECT FIND_IN_SET('b','a,b,c,d');  

        -> 2  

for example:  

$sql = "select p.*, find_in_set(p.products_id,$string_hot_pid) as rank from products p where p.products_id in ($string_hot_pid) order by rank";  

 

本文轉載至:http://database.51cto.com/art/201011/235318.htm

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.