我正在尝试使用 whereBetween 在 Laravel 中构建一个查询,但我对日期范围有疑问。我使用 Carbon 来获取输入,如下所示:
$dateRange = Carbon::parse($request->get('anniversary'));
我在提交时收到以下错误:
DateTime::__construct(): Failed to parse time string (06/01/2019 - 06/30/2019) at position 11 (-): Unexpected character
然后,我以这种形式更改了 $dateRange:
$dateRange = Carbon::parse(str_replace('-', '', $request->get('anniversary')));
之后出现了这个错误:
DateTime::__construct(): Failed to parse time string (06/01/2019 06/30/2019) at position 12 (0): Double date specification
whereBetween 子句如下所示:
->whereBetween('anniversary', [$dateRange])
关于如何解决这个问题有什么想法吗?
您需要将检索到的日期选择器分解为两个值。 (开始日期和结束日期)
$dateArray = explode('-', $request->get('anniversary'));
$startDate = $dateArray[0];
$endDate = $dateArray[1];
现在您可以使用
->whereBetween('anniversary', $dateArray);