group by 查找订单的最新状态 join

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了group by 查找订单的最新状态 join相关的知识,希望对你有一定的参考价值。

Order:sn
Procedures:sn,status
1、 有订单表和流程表。
订单表含有订单的详细信息【假设没有订单状态哈】,每个订单有好多种状态:已付款、处理中、待收货等等。现在的需求可能是查询订单状态是待收货的所有订单的信息。
【答】先找到最新状态是待收货的所有订单,然后和订单表做一个left join,就可以得到了。
一、 先找最新状态是待收货的所有订单。
本来拍脑袋一想是group by order by 取第一条,然后试了一下,发现group by取回来的并不是最新状态的,而是分组后的第一条。这是因为在mysql中语句的执行顺序是先执行group by 然后执行order by .很明显这就不可能得到最新的一条了。我们可以这样查出每个订单的最新状态
select sn,max(status) from procedures group by sn .
正确的是下面的写法,自己和自己做个join,最后再和order join。
SELECT a.id, a.sn, a.created_at,a.type FROM (SELECT sn, max(created_at) created_at FROM procedures GROUP BY sn ) b JOIN procedures a ON a.sn = b.sn AND a.created_at = b.created_at where a.type=11

select c.*,tmp.type from complaints as c right join (
SELECT a.id, a.sn, a.created_at,a.type FROM (SELECT sn, max(created_at) created_at FROM procedures GROUP BY sn ) b JOIN procedures a ON a.sn = b.sn AND a.created_at = b.created_at where a.type=11
) as tmp on tmp.sn=c.sn

以上是关于group by 查找订单的最新状态 join的主要内容,如果未能解决你的问题,请参考以下文章

SQL Server:带有 GROUP BY 子句的 OUTER JOIN 不会返回所有可能的组合?

MySQL中最新订单状态的SQL查询

利用 group by 的 Loose Index Scan 优化 sql

通过 JOIN 和 GROUP BY 获取最近的行?

Mongodb:通过最高的邮政编码城市人口查找具有最高数量的邮政编码和订单状态的城市

在 MongoDB 中使用 group by、inner join 和嵌套条件进行聚合