国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

MySQL關(guān)于字符串中數(shù)字排序的問題分析

2024-07-24 13:09:54
字體:
供稿:網(wǎng)友

本文實(shí)例講述了MySQL關(guān)于字符串中數(shù)字排序的問題。分享給大家供大家參考,具體如下:

MySQL字符串相信大家都不陌生,在MySQL字符串排序時(shí)經(jīng)常會遇到一些問題,比如下面要介紹的這個(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:

復(fù)制代碼 代碼如下:
$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";

 

大家有什么好的想法和建議可以留下寶貴的意見 以便共同進(jìn)步

希望本文所述對大家MySQL數(shù)據(jù)庫計(jì)有所幫助。

 


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 巫山县| 兰考县| 许昌市| 大化| 依兰县| 金昌市| 横山县| 清涧县| 沭阳县| 富平县| 巨鹿县| 隆子县| 黎川县| 府谷县| 南皮县| 长岭县| 绥中县| 松阳县| 滦平县| 嘉义县| 石首市| 韶关市| 延吉市| 阿合奇县| 子长县| 永清县| 含山县| 河北省| 南召县| 色达县| 嘉峪关市| 萍乡市| 梁山县| 马鞍山市| 德化县| 霍林郭勒市| 横峰县| 邵东县| 连州市| 玛纳斯县| 铁岭县|