gpt4 book ai didi

mysql - 通过 MySQL 中每个组的最后 N 行获取状态

转载 作者:可可西里 更新时间:2023-11-01 07:32:27 26 4
gpt4 key购买 nike

这是简化表(sqlfiddle):

id  group   status
-- ------ -------
1 group1 success
2 group1 fail
3 group1 success

4 group2 success

5 group3 fail
6 group3 success
7 group3 success
8 group3 success

我需要通过最后 N 行获取每组失败的结果信息。像这样(N=3):

group   has_failures
------ ------------
group1 1
group2 0
group3 0

获取群组非常容易:

-- Select last row from each group:
SELECT a.id, a.group, a.status
FROM log a
INNER JOIN(
select max(i.id) as max_id
from log i
group by i.group
) as b on a.id = b.max_id;

失败也是如此:

-- Select fail status by last 3 rows:
select count(g.status) > 0 as has_failures
from (
SELECT a.group, a.status
FROM log a
WHERE a.group = 'group3'
ORDER BY id DESC
LIMIT 3
) as g
where g.status = 'fail';

应该如何合并这两个查询,或者可能存在更简单的方法?

最佳答案

这是使用用户定义的变量 为每组建立行号的一个选项。然后你可以使用条件聚合:

select max(t.id) id,
t.group,
max(case when t.rank = 1 then t.status end) status,
sum(case when t.status = 'fail' then 1 else 0 end) hasfailures
from (
select *,
case l.group
when @curGroup
then @curRow := @curRow + 1
else @curRow := 1 AND @curGroup := l.group
end + 1 AS rank
from `log` l cross join (select @curRow:=0, @curGroup:='') c
order by l.group, id desc
) t
where rank <= 3
group by t.group

关于mysql - 通过 MySQL 中每个组的最后 N 行获取状态,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35976900/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com