Laravel渴望装载&whereHas

问题描述 投票:4回答:2

关于这个问题已经提出了几个问题,但没有一个问题为这个问题提供了令人满

我运行以下查询:

$return = Vacation::whereHas('dates', function ($query) use ($from, $to) {
    $query->whereBetween('start_date', [$from, $to]);
})->get();

根据查询日志,这将生成以下SQL。返回的结果是正确的,但JOINed数据存在问题。

select * from `vacations` where exists (select * from `vacation_dates` where `vacations`.`id` = `vacation_dates`.`vacation_id` and `start_date` between '2017-08-01 00:00:00' and '2017-08-30 00:00:00')

由于没有JOIN,之后通过急切加载添加相关记录,并且约束丢失。

该场景涉及Vacations,它有多个开始/停止日期,我想检查哪些假期在start_date$start日期范围内有$end

如果没有出现,则不返回任何记录。

发生时,将返回带有所有日期的休假,而不仅仅是约束中的日期。

我理解它是如何/正在做什么但是没有看到我如何得到我需要的东西:跟随约束的连接数据的记录。

任何人?

laravel eloquent
2个回答
5
投票

解:

$callback = function($query) use($from, $to) {
            $query->whereBetween('start_date', [$from, $to]);
        };
        $return = Vacation::whereHas('dates', $callback)->with(['dates' => $callback])->get();

Solution is from this SO post


1
投票

与@stef给出的答案相同,但语法更好看(我相信)

$return = Vacation::query()
    ->whereHas('dates', $datesFilter = function($query) use ($from, $to) {
        $query->whereBetween('start_date', [$from, $to]);
    })
    ->with(['dates' => $datesFilter])
    ->get();
© www.soinside.com 2019 - 2024. All rights reserved.