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

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

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

《L03 构架 API 服务器》
你将学到如 RESTFul 设计风格、PostMan 的使用、OAuth 流程,JWT 概念及使用 和 API 开发相关的进阶知识。
《G01 Go 实战入门》
从零开始带你一步步开发一个 Go 博客项目,让你在最短的时间内学会使用 Go 进行编码。项目结构很大程度上参考了 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’));
}
这样处理后就可以赋值成功了。

3年前 评论
讨论数量: 3

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

3年前 评论

sql打出来没有问题

3年前 评论

问题已解决
控制器:
$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’));
}
这样处理后就可以赋值成功了。

3年前 评论

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