0

我正在使用 CakePHP 搜索插件http://cakedc.com/downloads/view/cakephp_search_plugin并想要创建一个 arg 来搜索多个字段我有数组 filterArgs 如下

var $filterArgs = array(
      array('name' => 'search', 'type' => 'like', 'field' => 'Interview.title_en'),
    );

我希望搜索 arg 不仅搜索字段 Interview.title_en 还搜索我尝试过的另一个字段

var $filterArgs = array(
      array('name' => 'search', 'type' => 'like', 'field' => array('Interview.title_en',  'Interview.Desc'));

但它不起作用!

有什么建议么?

4

1 回答 1

4

为了实现这一点,您必须在模型中创建一个简单的方法,该方法为搜索字段构建“OR”条件。

public $filterArgs = array(
    array('name' => 'q', 'type' => 'query', 'method' => 'filterQuery'),
);

public function filterQuery($data = array()) {
    if(empty($data['q'])) { // q is the name of my search field
        return array();
    }

    $query = '%'.$data['q'].'%';
    return array(
        'OR' => array(
            'Model.title LIKE' => $query,
            'Model.description LIKE' => $query,
            'Model.resources LIKE' => $query,
        )
    );
}
于 2011-07-26T09:04:45.550 回答