mysql查询每个用户最新的一条订单

表结构:id,user_id,order_status,create_time,update_time…

子查询加表连接查询:

select b.* FROM (
	 SELECT max(create_time) as create_time,user_id
	 FROM order_record
	 WHERE order_status = 2 group by user_id) a
 LEFT JOIN order_record b
 ON a.user_id= b.user_idand a.create_time= b.create_time;

子查询:根据用户id分组查询出创建时间最新的那个订单的create_time和用户id
表连接:将子查询的临时表和原表order_record左连接,连接条件是子查询的查询结果字段

根据自身业务可以调整子查询的查询结果列,我这里是按最新的create_time,如果id是自增的也可以用max(id),相应调整表连接的条件即可。

子查询的查询结果为什么不直接把id查出来?
如下:

SELECT max(create_time) as create_time,id
	 FROM order_record
	 WHERE order_status = 2 group by user_id

这样查询其实有问题,如用户有两个订单id分别为1、2,第一个创建时间是2022-9-6 10:49:07,第二个创建时间是2022-9-6 13:49:18,此时查询结果是【create_time:2022-9-6 13:49:18 , id:1】。可以发现不是我们预期的,所以这样查是不准确的。

所以采用子查询加表连接的方式,前提是表连接后每个用户的查询的结果是唯一的。

例如,上述使用最大的创建时间,那么如果创建时间最大且相同的有多个,连接后的查询结果就会有多个。但是这样也不会有太大的问题,可以在代码里根据用户id分组,然后取列表的第一个,我想是没太大问题的,毕竟最新的有多个(创建时间相同),它们都是最新的,从业务上取哪一个都没问题。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员 beige

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值