whereBetween方法验证列的值是否在between之间
两个值。
$from = date('2018-01-01');
$to = date('2018-05-02');
Reservation::whereBetween('reservation_from', [$from, $to])->get();
在某些情况下,需要动态添加日期范围。根据@Anovative的评论,你可以这样做:
Reservation::all()->filter(function($item) {
if (Carbon::now()->between($item->from, $item->to)) {
return $item;
}
});
如果你想添加更多的条件,那么你可以使用orWhereBetween。如果你想要排除一个日期间隔,那么你可以使用whereNotBetween。
Reservation::whereBetween('reservation_from', [$from1, $to1])
->orWhereBetween('reservation_to', [$from2, $to2])
->whereNotBetween('reservation_to', [$from3, $to3])
->get();
其他有用的where子句:whereNotIn, whereenull, whereNotNull, whereDate, whereMonth, whereDay, whereYear, whereTime, whereColumn, whereExists, whereRaw。
Laravel关于Where子句的文档。