程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL字符串中數字排序的問題

MySQL字符串中數字排序的問題

編輯: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. mysql> SELECT FIND_IN_SET('b','a,b,c,d');  
  2.         -> 2  
  3.    
  4. for example:  
  5. $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";  

MySQL字符串相加函數用法示例

MySQL大表重復字段的查詢方法

MYSQL查詢重復記錄的方法

教您如何實現MySQL全文查詢

MySQL隨機查詢的實現方法

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved