相关疑难解决方法(0)

Laravel渴望装载&whereHas

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

我运行以下查询:

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

根据查询日志,这将生成以下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')
Run Code Online (Sandbox Code Playgroud)

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

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

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

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

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

任何人?

laravel eloquent

4
推荐指数
2
解决办法
1624
查看次数

Laravel - 有没有办法结合哪里有和有

我目前面临一个小问题.我想仅在存在具有特定条件的关系时才返回模型.使用whereHas()方法可以正常工作.

$m = Model
    ::whereHas(
        'programs',
        function($q) {
            $q->active();
        }
    );
Run Code Online (Sandbox Code Playgroud)

但是,将关系称为此类属性将为我提供所有(未过滤结果).

$m->programs;
Run Code Online (Sandbox Code Playgroud)

基本上我现在正在做的是:

$m = Model
    ::whereHas(
        'programs',
        function($q) {
            $q->active();
        }
    )
    ->with(array('programs' => function($q) {
        $q->active();
    }))
;
Run Code Online (Sandbox Code Playgroud)

这工作正常但我觉得再次做同样的事情非常糟糕.这不是正确的方法.如何在不重复代码的情况下实现这一目标?

php laravel laravel-4

3
推荐指数
1
解决办法
1119
查看次数

标签 统计

laravel ×2

eloquent ×1

laravel-4 ×1

php ×1