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

发布时间:2020-06-05 06:29:22 作者:努力的C
来源:网络 阅读:1002

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

推荐阅读:
  1. 还在手动编写GROUP BY子句?SQL Prompt可以自
  2. MySQL Group Replication (MGR) 安装

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

group by join left join

上一篇:php7中include 和 require 语句用法和区别

下一篇:使用 Ghidra 分析 phpStudy 后门

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》