mysql 分组后每个取最新的一条记录
在MySQL中,可以使用子查询和LIMIT关键字来实现分组后每个组取最新的一条记录。以下是两种不同的实现方法:
方法1: 使用子查询和LIMIT子句
SELECT t1.*
FROM your_table t1
INNER JOIN (
SELECT group_column, MAX(date_column) AS max_date
FROM your_table
GROUP BY group_column
) t2 ON t1.group_column = t2.group_column AND t1.date_column = t2.max_date;
方法2: 使用窗口函数ROW\_NUMBER()
SELECT *
FROM (
SELECT *,
ROW_NUMBER() OVER (PARTITION BY group_column ORDER BY date_column DESC) AS rn
FROM your_table
) t
WHERE rn = 1;
这两种方法都可以确保每个分组中只选择最新的一条记录。在方法1中,先通过子查询找到每个分组中的最新日期,然后通过连接操作获取对应的记录。在方法2中,使用窗口函数ROW\_NUMBER()对每个分组内的记录进行排序,并给每条记录分配一个行号,然后筛选出行号为1的记录。
请注意,上述代码的"your\_table"代表你的表名,"group\_column"代表用于分组的列名,"date\_column"代表用于比较的日期列名。根据实际情况,你需要将这些名称替换为你自己的表和列名。
评论已关闭