官方文档
https://www.kancloud.cn/manual/thinkphp5/139045
V5.0.7版本以上,支持使用数组方式定义嵌套预载入,例如下面的预载入要同时获取用户的Profile关联模型的Phone、Job和Img子关联模型数据:
php
$list = User::with(['profile'=>['phone','job','img']])->select([1,2,3]);
foreach($list as $user){
// 获取用户关联
dump($user->profile->phone);
dump($user->profile->job);
dump($user->profile->img);
}
实际操作时发现问题,关联模型里面必须要哪个in方式查询(默认的),如果使用fastadmin自动生成的代码,默认是join查询,所以无效
public function profile()
{
// 设置预载入查询方式为IN方式
return $this->hasOne('Profile')->setEagerlyType(1);
}