mysql "group by"與"order by"的研究--分類中最新的內(nèi)容
更新時間:2010年06月21日 12:31:07 作者:
這兩天讓一個數(shù)據(jù)查詢難了。主要是對group by 理解的不夠深入。才出現(xiàn)這樣的情況
這兩天讓一個數(shù)據(jù)查詢難了。主要是對group by 理解的不夠深入。才出現(xiàn)這樣的情況
這種需求,我想很多人都遇到過。下面是我模擬我的內(nèi)容表
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');

我現(xiàn)在需要取出每個分類中最新的內(nèi)容
select * from test group by category_id order by `date`
結(jié)果如下

明顯。這不是我想要的數(shù)據(jù),原因是msyql已經(jīng)的執(zhí)行順序是
寫的順序: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)容。

到group by時就得到了根據(jù)category_id分出來的多個小組


到了select的時候,只從上面的每個組里取第一條信息結(jié)果會如下

即使order by也只是從上面的結(jié)果里進(jìn)行排序。并不是每個分類的最新信息。
回到我的目的上 --分類中最新的信息
根據(jù)上面的分析,group by到select時只取到分組里的第一條信息。有兩個解決方法
1,where+group by(對小組進(jìn)行排序)
2,從form返回的數(shù)據(jù)下手腳(即用子查詢)
由where+group by的解決方法
對group by里的小組進(jìn)行排序的函數(shù)我只查到group_concat()可以進(jìn)行排序,但group_concat的作用是將小組里的字段里的值進(jìn)行串聯(lián)起來。

再改進(jìn)一下

子查詢解決方案
這種需求,我想很多人都遇到過。下面是我模擬我的內(nèi)容表
復(fù)制代碼 代碼如下:
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');

我現(xiàn)在需要取出每個分類中最新的內(nèi)容
復(fù)制代碼 代碼如下:
select * from test group by category_id order by `date`
結(jié)果如下

明顯。這不是我想要的數(shù)據(jù),原因是msyql已經(jīng)的執(zhí)行順序是
引用
寫的順序: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)容。

到group by時就得到了根據(jù)category_id分出來的多個小組


到了select的時候,只從上面的每個組里取第一條信息結(jié)果會如下

即使order by也只是從上面的結(jié)果里進(jìn)行排序。并不是每個分類的最新信息。
回到我的目的上 --分類中最新的信息
根據(jù)上面的分析,group by到select時只取到分組里的第一條信息。有兩個解決方法
1,where+group by(對小組進(jìn)行排序)
2,從form返回的數(shù)據(jù)下手腳(即用子查詢)
由where+group by的解決方法
對group by里的小組進(jìn)行排序的函數(shù)我只查到group_concat()可以進(jìn)行排序,但group_concat的作用是將小組里的字段里的值進(jìn)行串聯(lián)起來。
select group_concat(id order by `date` desc) from `test` group by category_id

再改進(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

子查詢解決方案
select * from (select * from `test` order by `date` desc) `temp` group by category_id order by `date` desc
相關(guān)文章
SQLServer與Oracle常用函數(shù)實例對比匯總
這篇文章主要介紹了SQLServer與Oracle常用函數(shù)對比,需要的朋友可以參考下2014-06-06DBeaver操作數(shù)據(jù)表的拷貝的實現(xiàn)
這篇文章主要介紹了DBeaver操作數(shù)據(jù)表的拷貝的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11OceanBase建表分區(qū)數(shù)超限報錯解決分析
這篇文章主要為大家介紹了OceanBase建表分區(qū)數(shù)超限報錯解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09大數(shù)據(jù)開發(fā)phoenix連接hbase流程詳解
HBase是一個分布式的、面向列的開源數(shù)據(jù)庫,該技術(shù)來源于?Fay?Chang?所撰寫的Google論文“Bigtable:一個結(jié)構(gòu)化數(shù)據(jù)的分布式存儲系統(tǒng)”。就像Bigtable利用了Google文件系統(tǒng)(File?System)所提供的分布式數(shù)據(jù)存儲一樣,HBase在Hadoop之上提供了類似于Bigtable的能力2022-11-11MSSQL轉(zhuǎn)MySQL數(shù)據(jù)庫的實際操作記錄
今天把一個MSSQL的數(shù)據(jù)庫轉(zhuǎn)成MySQL,在沒有轉(zhuǎn)換工具的情況下,對于字段不多的數(shù)據(jù)表我用了如下手功轉(zhuǎn)換的方法,還算方便。MSSQL使用企業(yè)管理器操作,MySQL用phpmyadmin操作。2010-06-06SQL基礎(chǔ)教程之行轉(zhuǎn)列Pivot函數(shù)
這篇文章主要給大家介紹了關(guān)于SQL基礎(chǔ)教程之行轉(zhuǎn)列Pivot函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用SQL具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-098種主流NoSQL數(shù)據(jù)庫系統(tǒng)特性對比和最佳應(yīng)用場景
這篇文章主要介紹了8種主流NoSQL數(shù)據(jù)庫系統(tǒng)特性對比和最佳應(yīng)用場景,對選擇一個NoSQL數(shù)據(jù)庫來說是一個不錯的參考文章,需要的朋友可以參考下2014-06-06大數(shù)據(jù)量,海量數(shù)據(jù)處理方法總結(jié)
大數(shù)據(jù)量的問題是很多面試筆試中經(jīng)常出現(xiàn)的問題,比如baidu google 騰訊這樣的一些涉及到海量數(shù)據(jù)的公司經(jīng)常會問到。2010-11-11