繁体   English   中英

Laravel中的关系

[英]Wheredoesnthave relation in Laravel

我在使用Eloquent / Laravel进行查询时遇到问题。

这是我的模型:请求包含零个或多个要约。 要约可以是隐藏的(这是要约上设置的属性)。

我需要做的是检索所有有或没有报价的请求。 但是,如果有关联的要约,则要约必须具有属性hide = false。

我已经尝试了以下方法,但是似乎没有用。

$requests = Request::whereDoesntHave('offers', function ($query) use ($hideStatus) {
   $query->where('hide', true);
})->get();

我认为这只是我完全没有报价的请求。

任何想法?

仅供参考,我有Laravel 5.4

任何帮助将不胜感激!

谢谢

检查以下查询。 我没有测试查询,而是以我所拥有的知识来编写它。

$requests = Request::whereHas('offers', function ($query) {
                    $query->where('hide', false);
                })
                ->orDoesntHave('offers')
                ->get();

感谢大家的答复。 “ orDoesntHave”不起作用。 相反,似乎可以进行以下操作:

$requests = Request::whereHas('offers', function ($query) {
                $query->where('hide', false);
            })
            ->doesntHave('offers', 'or')
            ->get();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM