我正在查找两个日期之间的所有记录
我的变量
$start = '01/01/2009';
$end = '07/24/2019';
我试过了
$gross = $this->CartOrders->find('all')->where(['placed >=' => $start])->andWhere(['placed <=' => $end])->all();
以上的查询片段
... FROM cart_orders CartOrders
WHERE (placed >= :c0 AND placed <= :c1)
[params] => Array (
[:c0] => Array ( [value] => 01/01/2009 [type] => datetime [placeholder] => c0 )
[:c1] => Array ( [value] => 07/24/2019 [type] => datetime [placeholder] => c1 ) )
结果
Cake\ORM\ResultSet Object ( [items] => Array ( ) )
我也试过
$gross = $this->CartOrders->find('all')->where(function($exp) use($start,$end) {
$exp->lte('placed', $end);
$exp->gte('placed', $start);
return $exp;
})->all();
我也试过
$gross = $this->CartOrders->find('all')->where(function($q) use($start,$end) {
return $q->between('CartOrders.placed', $start, $end, 'date');
})->all();
我该怎么做呢?
4条答案
按热度按时间enyaitl31#
使用查询表达式
如果用户试图在同一天内搜索,则可能会添加一个time at条件
hc8w905p2#
请尝试使用
这是一个非正统的解决方案,但它已经为我的多种情况工作
elcex8rz3#
olhwl3o24#
这是一个日期格式问题。
以下解决了我的问题。
此链接帮助
PHP convert date format dd/mm/yyyy => yyyy-mm-dd