Laravel Datepicker 无法解析时间字符串

问题描述 投票:0回答:1

我正在尝试使用 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])

关于如何解决这个问题有什么想法吗?

laravel date parsing datepicker php-carbon
1个回答
1
投票

您需要将检索到的日期选择器分解为两个值。 (开始日期和结束日期)

$dateArray = explode('-', $request->get('anniversary'));

$startDate = $dateArray[0];
$endDate = $dateArray[1];

现在您可以使用

->whereBetween('anniversary', $dateArray);
© www.soinside.com 2019 - 2024. All rights reserved.