Eloquent MYSQL 语句:WHERE NOT(A OR B)
Eloquent MYSQL statement : WHERE NOT(A OR B)
我正在研究日期范围重叠功能,可以在 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);
});
我该如何解决这个问题?
这与我的另一个可能重复的 post 相关:Laravel / Eloquent WHERE NOT SUBQUERY
但我希望我的问题现在更清楚了。
您可以通过恢复 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);
我正在研究日期范围重叠功能,可以在 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);
});
我该如何解决这个问题?
这与我的另一个可能重复的 post 相关:Laravel / Eloquent WHERE NOT SUBQUERY
但我希望我的问题现在更清楚了。
您可以通过恢复 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);