我有这个Eloquent查询:
$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,join和SoftDeletes来查询该查询?
答案 0 :(得分:1)
您需要建立关系: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