kavo

thinkphp5关联预加载数据的条件查询显示

正常情况下我们可以在模型中

return $this->hasMany('User')->order('create_time desc');
这样来条件显示,不过这样只适合惰性加载,如果使用了with关联预加载,则条件就会失效。

所以这时我们要通过with闭包函数来解决这个问题

下面代码所示,在第一个with预加载中使用闭包,再使用一个嵌套预载入,然后跟链式条件查询,这样即可完成预载入的条件显示,链式条件可以重复并且多个叠加,理论没有限制,只要是query语句即可。

return self::with([
            'imgs' => function($query){
            $query->with('imgUrl')
                ->order('order','asc');
            }
        ])
            ->with('propetries')
            ->find($id);



posted on 2017-12-18 14:10  下雨天唱情歌  阅读(15)  评论(0编辑  收藏  举报  来源

导航