Mysql分组查询取max那条记录其它字段方式
Mysql分组查询取max那条记录其它字段
需求描述
现有有需求要按类型分组,查询出每一分组最近的一条记录,返回字段包含id,定时任务执行时间(start_time)和任务id(job_id)。
SELECT id, MAX(start_time) AS startTime,job_id AS jobId FROM `sta_task_alarm` GROUP BY `job_id`;
问题描述
上面这个SQL查询出来的id 并不是我们想要的max 那条记录的id,那么我们怎么查询到
MAX(start_time) 那条对应的 id和job_id(这个上面可以查询出来)呢?
想到用 GROUP_CONCAT 函数去实现:
SELECT SUBSTRING_INDEX( GROUP_CONCAT(id ORDER BY `id` DESC),',',1) AS id,job_id AS jobId SUBSTRING_INDEX( GROUP_CONCAT(start_time ORDER BY `start_time` DESC),',',1) AS startTime FROM `sta_task_alarm` GROUP BY job_id;
这样是可以实现,查询出的结果为:
这个结果是正确的。
验证一下原始数据:
最后:
其实因为id是自增的,按下面这样查就可以了:
SELECT MAX(id) AS id, job_id AS jobId, MAX(start_time) AS startTime FROM `sta_task_alarm` WHERE is_delete = 0 GROUP BY job_id;
执行结果:
Mysql分组查询max值所在的记录
临近下班,要写一个sql。着急下班,所以有点乱。想了半天没想出来这么写这个sql。查询表里的max值和这个值所在的记录。
晚上睡前才意识到自己吧内联inner jion 概念搞混了。inner只取字段相等的记录。所以查询伪代码如下。
例如,查询一个表 table 每一天记录的最大时间。
先查询这个表A中,每一天记录的最大时间。将查询结果作为另一个表B。然后将两个表关联,关联条件既B表最大时间等于A表时间和B表天数等于A表天数。
SELECT B.new_date, A.* FROM mytable AS A INNER JOIN ( SELECT max(date_time) new_date, myday FROM mytable GROUP BY myday ) AS B ON A.date_time = B.new_date AND A.myday = B.myday
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
select into from和insert into select的使用举例详解
select into from和insert into select都是用来复制表,下面这篇文章主要给大家介绍了关于select into from和insert into select使用的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下2023-04-04mysql临时表(temporary table)使用方法详解
MySQL临时表在很多场景中都会用到,MySQL内部在执行复杂SQL时,需要借助临时表进行分组、排序、去重等操作,下面这篇文章主要给大家介绍了关于mysql临时表(temporary table)使用方法的相关资料,需要的朋友可以参考下2024-01-01
最新评论