在 Yii 2.0 中 的 ActiveDataFilter 实现,不存在的字段的筛选参数的支持

1、在选题列表页面中,是否已延期,0:否;1:是,此字段在选题表中并不存在。是通过程序计算得出。$time 为当前北京时间,由服务端计算得出。如图1

图1

$result['items'][$i]['is_deferred'] = ($item['status'] != Plan::STATUS_COMPLETED && $time > $item['ended_at']) ? 1 : 0 ;

2、在最新版本的原型中,需要支持字段:is_deferred 的筛选。如图2

图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

图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

图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 实现中,如果不存在的字段需要参与筛选,则需要想办法转换为表中已存在的字段。以利用框架自带的底层实现。避免筛选参数的手动转换。

 

永夜