Maison >développement back-end >tutoriel php >Yii2 réalise la méthode de recherche de plusieurs champs en même temps
Cet article présente principalement la méthode de Yii2 pour réaliser une recherche simultanée de plusieurs champs. Il analyse les fonctions et les méthodes d'utilisation spécifiques utilisées dans Yii2 pour rechercher plusieurs champs en même temps sous forme d'exemples auxquels les amis dans le besoin peuvent se référer. it
L'exemple de cet article décrit comment Yii2 implémente la recherche de plusieurs champs en même temps. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :
Le champ de recherche dans Yii2 utilise la méthode andFilterWhere, qui peut être utilisée pour rechercher un paragraphe.
Si vous recherchez plusieurs champs, par exemple si le titre de l'article et le contenu de l'article contiennent les mots-clés qui doivent être recherchés, car la relation entre eux est ou, vous devez donc utiliser orFilterWhereCette méthode
Ce qui suit est tout le code
public function actionIndex() { $key =Yii::$app->request->post("key"); $query = Post::find()->joinWith('cate'); $post = $query->orderBy(['post.id' => SORT_DESC])->asArray()->where(['post.status' => 1]); if($key){ $post->andFilterWhere(['like', 'post.title', $key]) ->orFilterWhere(['like', 'post.content', $key]); } $pages = new Pagination([ 'totalCount' => $post->count(), 'defaultPageSize' => 10 ]); $model = $post->offset($pages->offset)->limit($pages->limit)->all(); return $this->render('index', [ 'model' => $model, 'pages' => $pages, ]); }
Vous pouvez voir l'instruction SQL comme suit :
Copiez le code Le code est le suivant :
select count(*) from `post` left join `category` on `post`.`cate_id`=`category`.`id` where ((`post`.`status`=1) and (`post`.`title` like '%key%')) or (`post`.`content` like '%key%') order by `post`.`id` desc select `post`.* from `post` left join `category` on `post`.`cate_id`=`category`.`id` where ((`post`.`status`=1) and (`post`.`title` like '%key%')) or (`post`.`content` like '%key%') order by `post`.`id` desc limit 10
Recommandations associées :
Yii implémente deux méthodes d'ajout de valeurs par défaut aux modèles
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!