Я хочу создать этот запрос с помощью модели поиска yii2
select * from t1 where (title = 'keyword' or content = 'keyword') AND
(category_id = 10 or term_id = 10 )
Но я не знаю, как использовать orFilterWhere
и andFilterWhere
.
Мой код в поисковой модели:
public function search($params) {
$query = App::find();
//...
if ($this->keyword) {
$query->orFilterWhere(['like', 'keyword', $this->keyword])
->orFilterWhere(['like', 'content', $this->keyword])
}
if ($this->cat) {
$query->orFilterWhere(['category_id'=> $this->cat])
->orFilterWhere(['term_id'=> $this->cat])
}
//...
}
Но он создает этот запрос:
select * from t1 where title = 'keyword' or content = 'keyword' or
category_id = 10 or term_id = 10