雄辩的MYSQL声明:何处(A或B)

时间:2017-04-05 14:09:19

标签: php laravel laravel-5 eloquent laravel-eloquent

我正在研究日期范围重叠功能,可以在13个正面条件下编写,以检查日期间隔是否重叠:

https://en.wikipedia.org/wiki/Allen%27s_interval_algebra

在2个负面条件下更优雅:

http://baodad.blogspot.nl/2014/06/date-range-overlap.html

在MYSQL中:

WHERE NOT(`last_day` <= '2001-06-01' OR `first_day` >= '2022-12-01');

这需要这样的东西,我无法在文档中找到:

$query = $query->whereNot(function ($query) use ($first_day, $last_day) {
   $query->where('last_day', '<=', $first_day);
   $query->orWhere('first_day', '<=', $last_day);
});

我该如何解决这个问题?

这与我的其他可能重复的帖子有关:Laravel / Eloquent WHERE NOT SUBQUERY

但我希望我的问题现在更清楚了。

1 个答案:

答案 0 :(得分:1)

您可以通过恢复 last_day first_day 上的约束来实现所需的功能 - 这样就无需使用 NOT 子句。

而不是做

WHERE NOT(`last_day` <= '2001-06-01' OR `first_day` >= '2022-12-01');

你可以做到

WHERE `last_day` > '2001-06-01' AND `first_day` < '2022-12-01';

使用Eloquent构建器,以下应该可以解决问题:

$query = $query->where('last_day', '>', $first_day)->where('first_day', '>', $last_day);