yii中cgridview中的多重比较

时间:2013-11-12 17:14:19

标签: yii filtering cgridview

在cgridview中有一个空白字段来过滤每列上面的数据我如何根据多重比较creteria过滤数据,例如我可以在ID列的此字段中输入> 5来过滤数据只是来自id 6及以上。 我想放一些像> 5和< 10我该怎么做

2 个答案:

答案 0 :(得分:0)

您创建$filter YourModel个实例并实施自定义search()方法,如图所示here

控制器:

public function actionIndex() {
    $filter = new YourModel('search');
    $filter->unsetAttributes();
    if (isset($_GET['YourModel']))
        $filter->attributes = $_GET['YourModel'];
    $this->render('yourview', array(
        'filter' => $filter,
    ));
}

查看:

<?php $this->widget('zii.widgets.grid.CGridView', array(
    'dataProvider' => $filter->search(),
    'filter' => $filter
    ...
));

结果,$filter模型的属性包含用户放在CGridView的过滤器输入字段中的值,其search()方法可以解析并以任何方式使用这些值来创建所需的值CDbCriteria然后返回已过滤的CActiveDataProvider

我没有对它进行测试,但为了过滤模型的某些属性field,我可以编写如下内容:

public function search()
{
    $criteria = new CDbCriteria();
    $matches = array();
    if (preg_match('/^(<|>)(.+)$/', $this->field, $matches))
    {
        $criteria->addCondition('field ' . $matches[1] . ' :field');
        $criteria->params[':field'] = $matches[2];
    }
    else
    {
        $criteria->addCondition('field = :field');
        $criteria->params[':field'] = $this->field;
    }

    // TODO: add conditions for other fields

    return new CActiveDataProvider($this, array(
        'criteria' => $criteria,
    ));
}

如果您希望在一个过滤器字段中同时包含<>条件,则由您决定使用哪种格式以及如何解析它以准备搜索条件。

答案 1 :(得分:0)

在我的情况下,我使用此代码:

    $matches=array();
    if(preg_match('/(.+)(\s)(.+)/',$this->field,$matches)) {
        $criteria->addCondition("field ".$matches[1]." and field ".$matches[3]);
    } else {
        $criteria->compare('field',$this->field);
    }

在cgridview中的过滤器输入中,我可以使用“&lt; 100&gt; 50”(在这种情况下,空白字符很重要)