模型内进行关联的方法名是驼峰法还是下划线连接的问题

浏览:972 发布日期:2016/12/09 分类:ThinkPHP5专区
现有User模型(对应表user)、UserGroup模型(对应表user_group)

使用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__title的数据;

接下来在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?
最佳答案
评论( 相关
后面还有条评论,点击查看>>