我有一个雄辩的问题:
$datos = Medidore::select([
'medidores.*',
'empresas.name as empresa',
'tipo_medidor.descripcion as tipomedidor',
'tipo1.descripcion as canal_1',
'tipo2.descripcion as canal_2'])
->join('empresas', 'medidores.empresa_id', '=', 'empresas.id')
->join('tipo_medidor', 'medidores.cod_tipo_medidor', '=', 'tipo_medidor.id')
->join('tipo_canal_med as tipo1', 'medidores.canal1', '=', 'tipo1.id')
->join('tipo_canal_med as tipo2', 'medidores.canal2', '=', 'tipo2.id')
->whereNull('medidores.deleted_at')
->get();
它没有带来任何数据,为什么?如果我这样做,$datos = Medidore::all();它当然可以工作,因为我需要连接。
如何使用Eloquent、joins和SoftDeletes执行查询?
发布于 2018-05-10 04:52:19
你需要建立你的关系:https://laravel.com/docs/5.6/eloquent-relationships
在您的Medidore类中,它将是
public function empresa(){
return $this->belongsTo(Empresa::class);
}
最后,假设我正确理解了您的关系,您的查询将如下所示:
Medidore::with('empresa', 'tipoMedidor', 'canal1', 'canal2')->get();
Eloquent将自动考虑软删除。返回的Medidore
对象集合应该已经从数据库加载了$medidore->empresa
https://stackoverflow.com/questions/50261709
复制相似问题