yii2(时间区段)多条件搜索加分页(between)

这里的时间是date  我数据库存的是 时间戳   yii有个between

web页面就是两个input框 就不展示了  

andWhere和andFilterWhere都可以用来追加条件,只是andFilterWhere会忽略条件中的空值

时间区段搜索需要注意,开始时间不填/结束时间不填情况的搜索

 控制器:

$query = OrderDealer::find();
 
$this->get_search_date($query, 'create_time');

//yii自带的分页
$countQuery = clone $query;
$pages = new Pagination([
    'totalCount' => $countQuery->count(),
    'pageSize' => 10,
]);
$order_info = $query->offset($pages->offset)->limit($pages->limit)->orderBy($order)->all();
public function get_search_date($query, $field)
{
    $end_date = strtotime($this->_request->get('end_date')) + 86400 - 1;
    $start_date = strtotime($this->_request->get('start_date'));
    if ($end_date && $this->_request->get('end_date')) {
        $query->andWhere(['between', $field, $start_date, $end_date]);
    } else if ($start_date) {
        $query->andWhere(['>=', $field, $start_date]);
    } else if ($this->_request->get('end_date')) {
        $query->andWhere(['<=', $field, $end_date]);
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值