group by 查找订单的最新状态 join
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了group by 查找订单的最新状态 join相关的知识,希望对你有一定的参考价值。
Order:snProcedures: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 不会返回所有可能的组合?
利用 group by 的 Loose Index Scan 优化 sql