使用 Laravel 查询构建器针对具有日期列的表编写查询时,应该使用什么数据类型?以下应返回 13 个结果,但什么也不返回:
$date = new \DateTime("-2 days");
Model::whereDate($date)->get();
转储查询表明 laravel 正在尝试这个:
array(3) {
'query' =>
string(62) "select * from `table` where `date` = ?"
'bindings' =>
array(1) {
[0] =>
class DateTime#310 (3) {
public $date =>
string(19) "2013-10-07 14:39:11"
public $timezone_type =>
int(3)
public $timezone =>
string(3) "UTC"
}
}
'time' =>
double(5.55)
}
将查询写成Model::whereDate($date->format("Y-m-d"))->get()
这样是可行的,但似乎不像 Laravel 那样做。
我应该将特定的对象类型传递给查询以按日期列过滤吗?
编辑:此示例中的模型如下所示:
class Model extends Eloquent {
protected $table = 'table';
public function getDates() {
return array('date');
}
}
它引用的表如下所示:
CREATE TABLE table(
some_field VARCHAR(255),
date DATE
) ENGINE = 'InnoDB';
Laravel 认为日期列是一个字符串:Model::lists('date')
返回一个字符串数组,就像DB::table('table')->lists('date')
.
更改$date = new \DateTime("-2 days");
为$date = \Carbon\Carbon::now()->subDays(2)
不允许我date
直接使用 Carbon 对象查询列。
更新:无论出于何种原因,内置的 MySQLdate
对\Carbon\Carbon
我不起作用,所以最简单的解决方案是将一个作为查询范围编写:
public function scopeDate($query, \Carbon\Carbon $date) {
return $query->whereDate($date->toDateString());
}