Поиск плагина CakePHP во многих полях - PullRequest
0 голосов
/ 26 июля 2011

Я использую поисковый плагин CakePHP http://cakedc.com/downloads/view/cakephp_search_plugin и хочу создать аргумент для поиска по нескольким полям. У меня есть массив filterArgs следующим образом

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

Я хочу, чтобы поисковый аргумент нетолько поле Interview.title_en, но для поиска еще одного поля я пробовал что-то вроде

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

, но оно не работает !!

Есть предложения?

1 Ответ

4 голосов
/ 26 июля 2011

Чтобы достичь этого, вы должны создать в своей модели простой метод, который создает условия «ИЛИ» для поиска в полях.

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,
        )
    );
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...