【问题标题】:Laravel With WherehasLaravel 与 Wherehas
【发布时间】:2014-10-28 20:49:03
【问题描述】:

我正在使用查询来获取属于某个城市、属于某个事件的公司。

$companies = Event::find($id)->city->companies;

现在在我看来,我正在遍历公司以输出在那里工作的人员如下

@foreach($companies as $company)
    @foreach($company->persons as $person)
        ...
    @endforeach
@endforeach

唯一的问题是它还向我显示没有人员的公司

所以知道如何修改我的查询以仅显示有人员的公司

我在考虑 WhereHas,但我似乎无法理解将两者结合起来的逻辑。

谢谢!

【问题讨论】:

    标签: php laravel laravel-4 eloquent


    【解决方案1】:

    我不确定它是否会起作用,但你可以试试这个:

    $companies = Event::find($id)->city->companies()->has('persons')->get();
    

    【讨论】:

    【解决方案2】:

    根据the documentation

    [...] 您可能希望根据是否存在 关系 [...] 为此,您可以使用 has 方法。

    这样的事情可能会奏效:

    Event::find($id)->city()->companies()->has('persons')->get();
    

    鉴于我不知道正确方法链接的确切返回对象。

    【讨论】:

      猜你喜欢
      • 2018-09-18
      • 2020-09-16
      • 2014-01-11
      • 2020-12-23
      • 2021-05-25
      • 2017-09-21
      • 1970-01-01
      • 2018-10-18
      • 2021-09-05
      相关资源
      最近更新 更多