hasOne 关联查询外键值是 0 开头的,关联查不出数据????????????

return $this->hasOne(‘App\Models\BaiyingRegion’, ‘code’, ‘district’);

code和district 是010 ,0开头关联不出数据,需要做省市区关联查询,但是省ID,code是0开头的,就查不数据,不知道什么原因,大家有什么解决方案。感谢

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《L02 从零构建论坛系统》
以构建论坛项目 LaraBBS 为线索,展开对 Laravel 框架的全面学习。应用程序架构思路贴近 Laravel 框架的设计哲学。
最佳答案

问题已解决
控制器:
$res = UserAddress::where(‘user_id’, $user_id);
$res = $res->with([
‘getBaiyingRegionCity’ => function ($query) {
$query->select(‘code’, ‘parent_code’,’name’,’level’);
},
]);
$res = $res->orderBy(‘address_id’);
$res = $this->baseRepository->getToArrayGet($res);
var_dump($res);die;
model层:
public function getBaiyingRegionCity()
{
return $this->hasOne(‘App\Models\BaiyingRegion’, “code”, “city”);
}
这样写getBaiyingRegionCity 没有赋值成功;
把 $query->select(‘code’, ‘parent_code’,’name’,’level’); 需要查询的字段放到model里面就可以了;
public function getBaiyingRegionCity()
{
return $this->hasOne(‘App\Models\BaiyingRegion’, “code”, “city”)->select(array(‘code’, ‘name’));
}
这样处理后就可以赋值成功了。

4年前 评论
讨论数量: 3

建议把SQL打印出来 再进行判断

4年前 评论

sql打出来没有问题

4年前 评论

问题已解决
控制器:
$res = UserAddress::where(‘user_id’, $user_id);
$res = $res->with([
‘getBaiyingRegionCity’ => function ($query) {
$query->select(‘code’, ‘parent_code’,’name’,’level’);
},
]);
$res = $res->orderBy(‘address_id’);
$res = $this->baseRepository->getToArrayGet($res);
var_dump($res);die;
model层:
public function getBaiyingRegionCity()
{
return $this->hasOne(‘App\Models\BaiyingRegion’, “code”, “city”);
}
这样写getBaiyingRegionCity 没有赋值成功;
把 $query->select(‘code’, ‘parent_code’,’name’,’level’); 需要查询的字段放到model里面就可以了;
public function getBaiyingRegionCity()
{
return $this->hasOne(‘App\Models\BaiyingRegion’, “code”, “city”)->select(array(‘code’, ‘name’));
}
这样处理后就可以赋值成功了。

4年前 评论

讨论应以学习和精进为目的。请勿发布不友善或者负能量的内容,与人为善,比聪明更重要!