一个关于记录分组的问题

sayigood 2010-05-22 10:36:27
--
-- 表的结构 `test`
--

CREATE TABLE IF NOT EXISTS `test` (
`pid` int(11) NOT NULL,
`tid` int(1) DEFAULT NULL,
`dateline` int(11) DEFAULT NULL,
PRIMARY KEY (`pid`)
) ENGINE=MyISAM DEFAULT CHARSET=utf8;

--
-- 转存表中的数据 `test`
--

INSERT INTO `test` (`pid`, `tid`, `dateline`) VALUES
(1368605, 111632, 1212230610),
(1368606, 111812, 1212230613),
(1368640, 111812, 1212230927),
(1368649, 111795, 1212231003),
(1368660, 111795, 1212231152),
(1368699, 111795, 1212231549),
(1368701, 111795, 1212231558),
(1368731, 111795, 1212231803),
(1368738, 111812, 1212231858);
/*
问题需求:
按照tid分组,然后每组中取出dateline值最大的记录
将上面得到的记录按照dateline排序后,取出top2对应的pid

结果:
pid
1368605
1368738
1368731
*/

drop table test

...全文
119 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
sayigood 2010-05-22
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 acmain_chm 的回复:]

你可以先执行一下 select * from test order by tid,dateline desc 观察一下它的结果。

然后
手册中说明了 group by的一种特殊用法。即没有出现在group by 中的字段会选择第一个显示。
[/Quote]彻底明白了,看来真该抽时间好好学习mysql手册。
非常感谢!~
ACMAIN_CHM 2010-05-22
  • 打赏
  • 举报
回复
你可以先执行一下 select * from test order by tid,dateline desc 观察一下它的结果。

然后
手册中说明了 group by的一种特殊用法。即没有出现在group by 中的字段会选择第一个显示。
sayigood 2010-05-22
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 acmain_chm 的回复:]

建议你先自己试着解释一下这个SQL语句,否则别人也根本不知道你目前已经懂了什么,到什么层次,到底是哪儿不懂。

写出你自己的理解,然后让别人来看你的理解是否正确。 否则别人解释过简单你还是理解不了,解释得过细,可能又是根本不必要。
[/Quote]
select pid from (select * from test order by tid,dateline desc) t group by tid;
我的理解很肤浅,觉着这条语句分为两步:
第一步:用语句select * from test order by tid,dateline desc形成一个表t
第二部:把表t按照tid分组,然后选出pid(到此为止,无法继续思考下去,因为跟执行结果有差异)
ACMAIN_CHM 2010-05-22
  • 打赏
  • 举报
回复
可以参考一下手册。

MySQL官方文档 http://dev.mysql.com/doc/refman/5.1/zh/index.html
ACMAIN_CHM 2010-05-22
  • 打赏
  • 举报
回复
建议你先自己试着解释一下这个SQL语句,否则别人也根本不知道你目前已经懂了什么,到什么层次,到底是哪儿不懂。

写出你自己的理解,然后让别人来看你的理解是否正确。 否则别人解释过简单你还是理解不了,解释得过细,可能又是根本不必要。
sayigood 2010-05-22
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 acmain_chm 的回复:]
...
select pid from (select * from test order by tid,dateline desc) t group by tid;
....
[/Quote]我始终没有搞明白,这条语句是如何实现选出每组中dateline值最大的一条记录?你能解释一下吗?
ACMAIN_CHM 2010-05-22
  • 打赏
  • 举报
回复
其中一种方法如下。

mysql> select * from test order by tid,dateline desc;
+---------+--------+------------+
| pid | tid | dateline |
+---------+--------+------------+
| 1368605 | 111632 | 1212230610 |
| 1368731 | 111795 | 1212231803 |
| 1368701 | 111795 | 1212231558 |
| 1368699 | 111795 | 1212231549 |
| 1368660 | 111795 | 1212231152 |
| 1368649 | 111795 | 1212231003 |
| 1368738 | 111812 | 1212231858 |
| 1368640 | 111812 | 1212230927 |
| 1368606 | 111812 | 1212230613 |
+---------+--------+------------+
9 rows in set (0.00 sec)

mysql> select pid from (select * from test order by tid,dateline desc) t group by tid;
+---------+
| pid |
+---------+
| 1368605 |
| 1368731 |
| 1368738 |
+---------+
3 rows in set (0.00 sec)

mysql>
ACMAIN_CHM 2010-05-22
  • 打赏
  • 举报
回复
参考下贴中的多种方法,(N=1)

http://topic.csdn.net/u/20091231/16/2f268740-391e-40f2-a15e-f243b2c925ab.html
[征集]分组取最大N条记录方法征集,及散分....
先展示下效果 https://pan.quark.cn/s/e81b877737c1 Node.js 是一种基于 Chrome V8 引擎的 JavaScript 执行环境,它使开发者能够在服务器端执行 JavaScript 编程,显著促进了全栈开发的应用普及。 在 Node.js 的开发流程中,`node_modules` 文件夹用于存储所有依赖的模块,随着项目的进展,该文件夹可能会变得异常庞大,其中包含了众多可能已不再需要的文件和文件夹,这不仅会消耗大量的硬盘空间,还可能减慢项目的加载时间。 `ModClean 2.0` 正是为了应对这一挑战而设计的工具。 `ModClean` 是一款用于清理 `node_modules` 的软件,其核心功能是移除那些不再被使用的文件和文件夹,从而确保项目的整洁性和运行效率。 `ModClean 2.0` 是此工具的改进版本,在原有功能上增加了更多特性,从而提高了清理工作的效率和精确度。 在 `ModClean 2.0` 中,用户可以设置清理规则,例如排除特定的模块或文件类型,以防止误删重要文件。 该工具通常会保留项目所依赖的核心模块,但会移除测试、文档、示例代码等非运行时必需的部分。 通过这种方式,`ModClean` 能够协助开发者优化项目结构,减少不必要的依赖,加快项目的构建速度。 使用 `ModClean` 的步骤大致如下:1. 需要先安装 `ModClean`,在项目的根目录中执行以下命令: ``` npm install modclean -g ```2. 创建配置文件 `.modcleanrc.json` 或 `.modcleanrc.js`,设定希望清理的规则。 比如,可能需要忽略 `LICENSE` 文件或整个 `docs`...

57,064

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧