Laravel hasMany关系选择特定列问题

时间:2019-05-10 10:44:41

标签: php mysql laravel relationship has-many

我的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();

我进行了很多搜索,每个人都建议选择这种类型的数据,但是我不知道为什么在选择特定列时数据为空。

1 个答案:

答案 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();