我的laravel模型内部有关系
/**
* Relation with calculations table
*
* @return object
*/
public function calculations()
{
return $this->hasMany('App\Calculation');
}
当我选择关系为
的数据时$this->diamonds
->select('id', 'image', 'number', 'weight', 'diamond_date', 'price')
->with('calculations')->first();
它返回所有数据并且工作正常,但是当我想选择特定的列时,它返回[]空数组
$this->diamonds
->select('id', 'image', 'number', 'weight', 'diamond_date', 'price')
->with(['calculations', function($query){
$query->select('id', 'height', 'width')
}])->first();
我进行了很多搜索,每个人都建议选择这种类型的数据,但是我不知道为什么在选择特定列时数据为空。
答案 0 :(得分:1)
请记住,$query->select()
中必须有主键(本例中的id)才能实际检索必要的结果。*
$this->diamonds->select('id', 'image', 'number', 'weight', 'diamond_date', 'price')
->with(['calculations', function($query){
$query->select('id', 'diamond_id', 'height', 'width')
}])->first();