mysql - 怎么连表查订单列表和其操作记录?

查看:126
本文介绍了mysql - 怎么连表查订单列表和其操作记录?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

现有两个表,订单表order和订单操作记录表order_log。字段简化如下:

order:
id name time

order_log
id orderId message time

现在需要得到订单列表(是列表,不是单条订单),和对应订单的最近的一条记录,需要怎么写比较好?
现在能想到的是最糟糕的解决方案,就是先取订单,然后根据订单id取最近的记录。这样的话,一次列表查询需要查询十多次,开销太大,想知道有没有更好的办法。

解决方案

select o.*, ol.id log_id, ol.message, ol.time log_time  from 
`order` o left join `order_log`  ol on ol.`orderId` = (
select MAX(ol.id) from `order_log` ol where ol.orderId = o.id
);

这篇关于mysql - 怎么连表查订单列表和其操作记录?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆