Maison  >  Article  >  développement back-end  >  Comment réaliser une recherche simultanée de plusieurs champs dans Yii2

Comment réaliser une recherche simultanée de plusieurs champs dans Yii2

不言
不言original
2018-06-15 10:52:232579parcourir

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 :

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

Ce qui précède est l'intégralité contenu de cet article, j'espère qu'il sera utile à tout le monde. L'apprentissage est utile. Pour plus de contenu connexe, veuillez faire attention au site Web PHP en chinois !

Recommandations associées :

Comment implémenter le traitement des tâches de commande via Yii

Utilisez les autorisations rbac de Yii2 pour contrôler le menu du menu

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn