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

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

不言
Libérer: 2023-04-01 09:08:02
original
2630 Les gens l'ont consulté

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,
  ]);
}
Copier après la connexion

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
Copier après la connexion

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal