当前位置:Gxlcms > PHP教程 > mysql数据读取的算法问题

mysql数据读取的算法问题

时间:2021-07-01 10:21:17 帮助过:26人阅读

有个一对多的问题,
先从顾客表中,读出1000条数据,
再从订单表中,读出这1000个顾客的每位顾客的最新的订单记录,
再从服务表中,读出这1000个顾客的每位顾客的最新的服务记录
这个代码应该怎么写,才是最优的解法?

回复内容:

有个一对多的问题,
先从顾客表中,读出1000条数据,
再从订单表中,读出这1000个顾客的每位顾客的最新的订单记录,
再从服务表中,读出这1000个顾客的每位顾客的最新的服务记录
这个代码应该怎么写,才是最优的解法?

也就是说你查 1000 个顾客最新的交易记录,建议记下每个顾客的最新 订单 ID和 服务ID(可以考虑使用缓存,也可以直接在用户表中新增两个字段),这样就能用 in (ids) 一次查出,1000条对内存要求不是很大,可以直接查出来在代码中遍历。

# sql
select * from order where order_id in (order_ids)

# then php
foreach($orders as $order) {
    foreach($customers as $customer) {
        if ($customer->getCustomerId() == $order->getCustomerId()) {
            //...
        }
    }
}

人气教程排行