1、在选题列表页面中,是否已延期,0:否;1:是,此字段在选题表中并不存在。是通过程序计算得出。$time 为当前北京时间,由服务端计算得出。如图1
$result['items'][$i]['is_deferred'] = ($item['status'] != Plan::STATUS_COMPLETED && $time > $item['ended_at']) ? 1 : 0 ;
2、在最新版本的原型中,需要支持字段:is_deferred 的筛选。如图2
3、通过分析程序计算的规则,最终分析得出有待于生成的查询 SQL。1599189174 为当前北京时间,由客户端计算得出。
// 已延期 ((`pa_plan`.`status` != '6') AND (`pa_plan`.`ended_at` < '1599189174')) // 未延期 ((`pa_plan`.`status` = '6') OR (`pa_plan`.`ended_at` >= '1599189174'))
4、已延期的请求参数添加:filter[and][0][and][0][status][neq]=6&filter[and][0][and][1][ended_at][lt]=1599189174。符合预期。如图3
SELECT * FROM `pa_plan` WHERE (`pa_plan`.`is_deleted`=0) AND (((`pa_plan`.`created_at` >= '1573716153') AND (`pa_plan`.`created_at` <= '1599119824')) AND (`pa_plan`.`importance`='3') AND (`pa_plan`.`group_id`='015ce30b116ce86058fa6ab4fea4ac63') AND ((`pa_plan`.`status` != '6') AND (`pa_plan`.`ended_at` < '1599189174'))) ORDER BY `pa_plan`.`id` DESC LIMIT 20
5、未延期的请求参数添加:filter[and][0][or][0][status]=6&filter[and][0][or][1][ended_at][gte]=1599189174 。符合预期。如图4
SELECT * FROM `pa_plan` WHERE (`pa_plan`.`is_deleted`=0) AND (((`pa_plan`.`created_at` >= '1573716153') AND (`pa_plan`.`created_at` <= '1599119824')) AND (`pa_plan`.`importance`='3') AND (`pa_plan`.`group_id`='015ce30b116ce86058fa6ab4fea4ac63') AND ((`pa_plan`.`status`='6') OR (`pa_plan`.`ended_at` >= '1599189174'))) ORDER BY `pa_plan`.`id` DESC LIMIT 20
6、总结:在 Yii 2.0 中 的 ActiveDataFilter 实现中,如果不存在的字段需要参与筛选,则需要想办法转换为表中已存在的字段。以利用框架自带的底层实现。避免筛选参数的手动转换。
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/250554.html