首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Laravel通过Eloquent获取SoftDelete数据

Laravel通过Eloquent获取SoftDelete数据
EN

Stack Overflow用户
提问于 2018-05-10 04:42:12
回答 1查看 142关注 0票数 0

我有一个雄辩的问题:

代码语言:javascript
运行
复制
$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执行查询?

EN

回答 1

Stack Overflow用户

发布于 2018-05-10 04:52:19

你需要建立你的关系:https://laravel.com/docs/5.6/eloquent-relationships

在您的Medidore类中,它将是

代码语言:javascript
运行
复制
public function empresa(){
  return $this->belongsTo(Empresa::class);
}

最后,假设我正确理解了您的关系,您的查询将如下所示:

代码语言:javascript
运行
复制
Medidore::with('empresa', 'tipoMedidor', 'canal1', 'canal2')->get();

Eloquent将自动考虑软删除。返回的Medidore对象集合应该已经从数据库加载了$medidore->empresa

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50261709

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档