Maison >développement back-end >tutoriel php >Yii2 réalise la méthode de recherche de plusieurs champs en même temps

Yii2 réalise la méthode de recherche de plusieurs champs en même temps

不言
不言original
2018-05-08 16:30:191611parcourir

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!

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