如何分组取最新的数据

今天有个朋友问我:mysql 根据某个id进行分组,每个分组按时间排序取最新的一条记录,除了使用row_number函数,是否还有其他方法?

其实这是个老生常谈的问题了 ,并且会经常出现在各种面试题中,我给了这个朋友几个方案,他几乎没怎么考虑就选了最后一个:

        方案1:使用row_number,配合cte写法,具体就是:  with t as (select *,row_number() over (partition by id order by update_time desc) as rn from table )select * from t where id=1
        方案2:先按id分组找到最新的更新时间写到临时表 ,再和原表关联,

CREATE TEMPORARY TABLE tmp_table as select id,max(update_time) as update_time from table group by id;       select * from table a join tmp_table b on a.id=b.id and a.update_time=b.update_time

        方案3:使用子查询作为查询条件

select * from table a where a.update_time =(select max(b.update_time ) from table b where b.id=a.id)

        方案4:从业务层面优化,在表上加一个字段,isnewdata,bit型或者int型就好,每次在表中提交数据时,事务中先将要提交的数据所涉及的id,将历史数据isnewdata=1的更新为0,新提交的数据,isnewdata为1,然后增加一个索引isnewdata,或者如果需要和其他表关联的时候,增加复合索引,性能一下就上来了。

        以上方案中:方案1和方案2中规中矩,是大多数人的选择;方案3性能最差,但是也有一些习惯用子查询的人采用;方案4性能最好,只是需要对业务做一些改进。

        如果业务数据量不大,最多就几万条,用方案1,2,3均可。数据量不超过100万行,方案1和2还能勉强顶住。超过100万行,就要从业务层面去优化了,此时选择方案4是明智的

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要在MySQL分组最新数据,可以使用以下两种方法。 方法一:使用窗口函数和子查询 可以使用窗口函数和子查询来实现分组最新数据的操作。首先,使用ROW_NUMBER()函数在每个分组中按照排序字段进行降序排序,并为每行分配一个行号。然后,在外部查询中,选择行号为1的数据,即最新数据。 示例SQL语句如下: SELECT * FROM ( SELECT *, ROW_NUMBER() OVER(PARTITION BY 分组字段 ORDER BY 排序字段 DESC) AS rn FROM 表 ) pca WHERE pca.rn = 1; 这段SQL语句会先将数据按照分组字段和排序字段进行排序,然后使用ROW_NUMBER()函数为每个分组数据分配行号。最后,在外部查询中选择行号为1的数据,即每个分组中的最新数据。 方法二:使用子查询和GROUP BY语句 另一种方式是使用子查询和GROUP BY语句来实现分组最新数据的操作。首先,在子查询中,通过嵌套查询找到每个分组中的最大排序字段值。然后,在外部查询中,使用这些最大排序字段值和分组字段进行匹配,选择对应的数据。 示例SQL语句如下: SELECT * FROM 表 a WHERE a.排序字段 = ( SELECT MAX(b.排序字段) FROM 表 b WHERE b.分组字段 = a.分组字段 ) GROUP BY a.分组字段; 这段SQL语句会先在子查询中找到每个分组中的最大排序字段值,然后在外部查询中使用这些最大排序字段值和分组字段进行匹配,选择对应的数据。最后,使用GROUP BY语句对结果进行分组,确保每个分组只返回一行数据。 以上是两种在MySQL分组最新数据的方法,可以根据具体情况选择适合的方法来实现需求。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Mysql 如何分组查询最新的几种方案](https://blog.csdn.net/weixin_39120210/article/details/129437469)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值