日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL字符串中數(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ù)值排序
如:

 
 
 
  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()進(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ù)將完全不能工作:

 
 
 
  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字符串中數(shù)字排序的問題
文章起源:http://www.dlmjj.cn/article/dpodcje.html