溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql group by與order by的區(qū)別

發(fā)布時(shí)間:2021-09-24 10:33:41 來(lái)源:億速云 閱讀:160 作者:iii 欄目:數(shù)據(jù)庫(kù)

本篇內(nèi)容介紹了“mysql group by與order by的區(qū)別”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

代碼如下:


CREATE TABLE `test` (
`id` INT(10) NOT NULL AUTO_INCREMENT,
`name` VARCHAR(255) NOT NULL,
`category_id` INT(10) NOT NULL,
`date` TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
)
ENGINE=MyISAM
ROW_FORMAT=DEFAULT;
INSERT INTO `test` (`id`, `name`, `category_id`, `date`)
VALUES
(1, 'aaa', 1, '2010-06-10 19:14:37'),
(2, 'bbb', 2, '2010-06-10 19:14:55'),
(3, 'ccc', 1, '2010-06-10 19:16:02'),
(4, 'ddd', 1, '2010-06-10 19:16:15'),
(5, 'eee', 2, '2010-06-10 19:16:35');


mysql group by與order by的區(qū)別
我現(xiàn)在需要取出每個(gè)分類中最新的內(nèi)容

復(fù)制代碼 代碼如下:


select * from test group by category_id order by `date`


結(jié)果如下
mysql group by與order by的區(qū)別
明顯。這不是我想要的數(shù)據(jù),原因是msyql已經(jīng)的執(zhí)行順序是

引用


寫(xiě)的順序:select ... from... where.... group by... having... order by..
執(zhí)行順序:from... where...group by... having.... select ... order by...


所以在order by拿到的結(jié)果里已經(jīng)是分組的完的最后結(jié)果。
由from到where的結(jié)果如下的內(nèi)容。
mysql group by與order by的區(qū)別
到group by時(shí)就得到了根據(jù)category_id分出來(lái)的多個(gè)小組
mysql group by與order by的區(qū)別
mysql group by與order by的區(qū)別
到了select的時(shí)候,只從上面的每個(gè)組里取第一條信息結(jié)果會(huì)如下
mysql group by與order by的區(qū)別
即使order by也只是從上面的結(jié)果里進(jìn)行排序。并不是每個(gè)分類的最新信息。
回到我的目的上 --分類中最新的信息
根據(jù)上面的分析,group by到select時(shí)只取到分組里的第一條信息。有兩個(gè)解決方法
1,where+group by(對(duì)小組進(jìn)行排序)
2,從form返回的數(shù)據(jù)下手腳(即用子查詢)

由where+group by的解決方法
對(duì)group by里的小組進(jìn)行排序的函數(shù)我只查到group_concat()可以進(jìn)行排序,但group_concat的作用是將小組里的字段里的值進(jìn)行串聯(lián)起來(lái)。

select group_concat(id order by `date` desc) from `test` group by category_id


mysql group by與order by的區(qū)別
再改進(jìn)一下

select * from `test` where id in(select SUBSTRING_INDEX(group_concat(id order by `date` desc),',',1) from `test` group by category_id ) order by `date` desc


mysql group by與order by的區(qū)別

子查詢解決方案

select * from (select * from `test` order by `date` desc) `temp`  group by category_id order by `date` desc


mysql group by與order by的區(qū)別 

“mysql group by與order by的區(qū)別”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI