php n+1 problem and laravel预加载(orderBy排序)

本文介绍如何使用Laravel框架的预加载机制来优化数据库查询中的N+1问题,通过一次查询批量获取多个关联表的数据,并支持排序等功能。

场景

场景太多,基本上在一个表的场景中 如果需要嵌套它的关联表(relationship) 那么一般都会触发
eg:  Question Model And Answer Model 在问题的列表页面的一个区域展示相应的答案(一部分)
1.  1 Query
      select * from questions; 得到N条问题
2.  N Query 
    .  轮询获取问题下面的答案
       select * from answers where quersion_id = $question_id  

解决

. laravel框架预加载机制可以解决这个问题
. 预加载的原理是where in ($question_id_list)
  N+1次变成了2次查询
. 预加载还支持排序,方式:匿名函数传递$query查询器调用orderBy
    /**
     * 根据id获取包含topic多对多关系的信息
     * @param $id
     * @return mixed
     */
    public function byIdWithTopicsAndAnswers($id)
    {
        return Question::where(compact('id'))->with(['topic', 'answers' => function($query) {
            $query->orderBy('id', 'desc');
        }])->first();
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值