Laravel通过Eloquent获取SoftDelete数据

时间:2018-05-09 20:42:12

标签: laravel eloquent soft-delete

我有这个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来查询该查询?

1 个答案:

答案 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