MySql 分組排序求最值問題

首先昧绣,先明確一下問題,所謂求分組的最值意思的就是在sql里面使用group by之后,每個分組有多條數(shù)據(jù)缺猛,我們要根據(jù)一定條件取其中最大的一條或者多條!

先看一個數(shù)據(jù)表 blogs 結構椭符,簡單說一下荔燎,cat_id 就是分類ID,可以看到一個分類有多條記錄:

image

舉個非常典型的問題:

1.求某個分類ID下销钝,查看次數(shù)最多的3條數(shù)據(jù)有咨?這個問題很簡單,基本上大家都能寫出來這樣的sql:

select * from blogs where cat_id = $cat_id order by view_num desc limit 3;

2.求多個分類ID下蒸健,查看次數(shù)最多的3條數(shù)據(jù)呢摔吏?這個問題就在于求多個,也就是我要批量查詢纵装,不能一個個查征讲,有很多人圖省事就直接for循環(huán)一個個查了,如果說只有幾個ID這樣做還可以,如果有幾十個這樣的數(shù)據(jù)就意味著幾十次的查庫操作橡娄,對性能影響還是挺大的诗箍,所以必須想辦法!

sql如下:

select SUBSTRING_INDEX(GROUP_CONCAT(cat_id,'-',id ORDER BY view_num),',',3) from blogs where cat_id in(1,2,3,4) GROUP BY cat_id

這條語句看上去比較復雜挽唉,不要慌滤祖,SUBSTRING_INDEX 是內置函數(shù),功能類似于PHP里面的 substr瓶籽,在這意思是取前3個數(shù)據(jù)匠童,重點是 group_concat, 這個函數(shù)很多人都用過,但是我估計很多人都不知道后面還可以寫 order by塑顺,所以這條sql的意思就是在每個分組里面排序取前3個汤求。

但是取出來的數(shù)組格式并不好看俏险,是以 cat_id-id 這種形式取出來的,可以看到有多個:

image

后面的操作只能拿到代碼里面處理了扬绪,可能需要循環(huán)取出所有id竖独,然后批量獲取數(shù)據(jù),最后再拼接出來想要的數(shù)據(jù)挤牛!雖然比較麻煩莹痢,在代碼里面需要多出很多次for循環(huán)操作,但是相比于多查幾十次庫墓赴,這點代碼運行開銷還是很小的竞膳!

?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市诫硕,隨后出現(xiàn)的幾起案子顶猜,更是在濱河造成了極大的恐慌,老刑警劉巖痘括,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件长窄,死亡現(xiàn)場離奇詭異,居然都是意外死亡纲菌,警方通過查閱死者的電腦和手機挠日,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來翰舌,“玉大人嚣潜,你說我怎么就攤上這事∫渭” “怎么了懂算?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長庇麦。 經(jīng)常有香客問我计技,道長,這世上最難降的妖魔是什么山橄? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任垮媒,我火速辦了婚禮,結果婚禮上航棱,老公的妹妹穿的比我還像新娘睡雇。我一直安慰自己,他們只是感情好饮醇,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布它抱。 她就那樣靜靜地躺著,像睡著了一般朴艰。 火紅的嫁衣襯著肌膚如雪观蓄。 梳的紋絲不亂的頭發(fā)上混移,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天,我揣著相機與錄音蜘腌,去河邊找鬼沫屡。 笑死饵隙,一個胖子當著我的面吹牛撮珠,可吹牛的內容都是我干的。 我是一名探鬼主播金矛,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼芯急,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了驶俊?” 一聲冷哼從身側響起娶耍,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饼酿,沒想到半個月后榕酒,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡故俐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年想鹰,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片药版。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡辑舷,死狀恐怖,靈堂內的尸體忽然破棺而出槽片,到底是詐尸還是另有隱情何缓,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布还栓,位于F島的核電站碌廓,受9級特大地震影響,放射性物質發(fā)生泄漏剩盒。R本人自食惡果不足惜氓皱,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望勃刨。 院中可真熱鬧波材,春花似錦、人聲如沸身隐。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽贾铝。三九已至隙轻,卻和暖如春埠帕,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背玖绿。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工敛瓷, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人斑匪。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓呐籽,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蚀瘸。 傳聞我的和親對象是個殘疾皇子狡蝶,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內容

  • 關于Mongodb的全面總結 MongoDB的內部構造《MongoDB The Definitive Guide》...
    中v中閱讀 31,938評論 2 89
  • “如果座墊上沒有鑲嵌紐扣會不會更舒服?” 我和會打家具的二手店老板聊著贮勃。 “可我記得上上個禮拜你還說座墊上有紐扣真...
    達人小星星閱讀 236評論 0 0
  • 忙了一段時間贪惹,終于閑下來了。這周已經(jīng)到了上海寂嘉,在新公司里上班奏瞬。也感受了下在魔都的生活,第一次感覺上班原來可以這么...
    文_413a閱讀 242評論 0 1
  • 據(jù)說在深圳經(jīng)常會看到街上有武僧表演十八般武藝显蝌,某武僧生活艱難,為了混碗飯吃和徒弟表演起了碎玻璃订咸,一個節(jié)目剛結束就上...
    冷不伶仃來一個閱讀 1,696評論 1 1
  • 春芬一葉尖尖芽 炎炎夏日葉遮陽 一葉知秋風蕭瑟 冬至葉亡化春糧
    機車與狗閱讀 82評論 0 0