使用User关联预载入UserGroup模型,在User模型内定义关联:
public function userGroup()
{
return $this->belongsTo('userGroup');
}
控制器内使用关联预载入获取数据:$userModel = new User();
$list = $userModel->field('id','code_id''name','user_group_id')->with([
'userGroup' => function ($query) {
$query->withField('title');
}
])->limit(0,10)->select();
return json($list);
ajax请求时得到:{code_id:"a671993d",create_time:1480946494,id:1,name:"admin",userGroup:null,usergroup__title:"系统管理员"}
可看到userGroup并没有正确关联,而是在user对象里多出一个usergroup__ti接下来在User模型里增加如下关联:
public function user_group()
{
return $this->userGroup();
}
此时控制器里关联预载入读取改成:with([
'user_group' => function ($query) {
$query->withField('title');
}
])
之后获取数据一切正常:{"id":1,"code_id":"a671993d","name":"admin","create_time":1480946494,"user_group":{"title":"系统管理员"}}
是不是bug? 最佳答案
