Maison  >  Article  >  développement back-end  >  Compétences Laravel : explication de la méthode d'appel de chaîne de superposition de Query Builder

Compétences Laravel : explication de la méthode d'appel de chaîne de superposition de Query Builder

jacklove
jackloveoriginal
2018-07-06 17:36:181927parcourir

Cet article vous présente principalement les informations pertinentes sur l'appel de chaîne de superposition du générateur de requêtes Query Builder dans les compétences Laravel. L'article le présente en détail à travers l'exemple de code, qui a une certaine valeur d'apprentissage de référence pour les études ou le travail de chacun. en cas de besoin, vous pouvez venir jeter un oeil ci-dessous.

Introduction au générateur de requêtes

Le générateur de requêtes Laravel (générateur de requêtes) fournit une interface pratique et fluide pour établir et exécuter des recherches dans la base de données

utilise la liaison de paramètres PDO pour protéger l'application de l'injection SQL. Par conséquent, les paramètres entrants n'ont pas besoin d'être échappés avec des caractères spéciaux

qui peuvent essentiellement répondre à toutes les opérations de base de données et peuvent être exécutés sur tous les systèmes de base de données pris en charge

Introduction

Aujourd'hui, je voudrais vous présenter une petite astuce du constructeur de requêtes Laravel. Elle n'est pas mentionnée en détail dans les exemples de documents officiels, et ce n'est pas une compétence haut de gamme. les gens l’utilisent peut-être, non. Les étudiants qui le connaissent peuvent y jeter un œil.

Dans le code métier, les requêtes sont souvent effectuées en fonction de conditions différentes. Pour un exemple simple, nous souhaitons maintenant interroger la liste des utilisateurs, classée par ordre chronologique inverse, et le statut et le type peuvent être utilisés comme conditions de qualification.

Je l'ai écrit comme ça au début

 if($status && $type) {
 $users = User::where('status', $status)->where('type', $type)->latest()->get();
 } else if ($status) {
 $users = User::where('status', $status)->latest()->get(); 
 } else if ($type) {
 $users = User::where('status', $type)->latest()->get();
 } else {
 $users = User::latest()->get(); 
 }

Ce code est vraiment moche, beaucoup de code public, comme -> ;latest ()->get(), écrit quatre fois. Si le produit dit qu'aujourd'hui nous voulons le trier dans l'ordre, alors vous devez changer quatre endroits. Bien qu’il soit rapide de le modifier à l’aide d’un éditeur, il faut savoir qu’il ne s’agit là que de l’exemple le plus simple.

Après avoir lu le document, il existe une méthode when pour le jugement conditionnel. Un tas de fermetures ne sont pas idéales. Je croyais fermement qu'il devait y avoir une façon plus élégante de l'écrire, alors j'ai cherché sur stackoverflow, et bien sûr, le tout-puissant Waiguoren m'a donné la réponse.

Écriture améliorée :

 $query = User::query();
 // 如果用DB: $query = DB::table('user'); 
 if ($status) {
  $query->where('status', $status);
 }
 if ($type) {
  $query->where('type', $type);
 } 
 $users = $query->latest()->get();

Utilisez une variable pour enregistrer l'instance du constructeur de requête, puis superposez-y des contraintes, et enfin obtenez une collecte . La partie publique est placée au début et à la fin, et la structure est claire. Est-ce une question de jugement ?

Et nous pouvons également transmettre $query en tant que paramètre dans une méthode ou une fonction, encapsulant ensemble une logique commune pour faciliter plusieurs appels :

 function foo($query) {
  $query->with(['girl', 'gay'])
    ->latest()
    ->get();
 } 
 $query = User::query();
 $users = foo($query);

Il y a une mise en garde dans cette façon d'écrire. Une fois que vous appelez une méthode de contrainte telle que Where sur $query, la requête sera modifiée. Parfois, nous devons cloner une requête à l'avance.

Par exemple, par exemple, nous souhaitons obtenir des utilisateurs de type 1 et 2 en même temps

 $query_1 = User::query();
 $query_2 = clone $query_1; 
 $users_1 = $query_1->where('type', 1)->latest()->get();
 $users_2 = $query_2->where('type', 2)->latest()->get();
 // 错误 $users_2 = $query_1->where('type', 1)->latest()->get();
 // 这样写得到得是type = 1 and $type = 2

Bien que ce soit non écrit dans la documentation de laravel Cet exemple, mais mentionné :

Vous pouvez utiliser la méthode table de la façade DB pour démarrer la requête. Cette méthode de table renvoie une instance de générateur de requêtes pour la table de requête, vous permettant d'enchaîner plus de contraintes lors de l'interrogation et d'utiliser la méthode get pour obtenir le résultat final


Hors sujet

Précédent J'ai entendu certains anciens dire qu'ils ne voulaient pas de programmeurs qui ne connaissent que Baidu. À cette époque, je me sentais vraiment prétentieux, pas tous les moteurs de recherche, car je n'utilisais pas Google à cette époque. Maintenant, je ne veux pas travailler avec quelqu'un qui sait seulement que Baidu n'est qu'une recherche publicitaire, et tous les résultats de recherche sont absurdes.

Google et stackoverflow sont de très bonnes choses. Beaucoup d'entre eux sont compétents et fournissent des réponses professionnelles, de l'historique de l'ordinateur aux systèmes d'exploitation, en passant par les bases de données et divers langages de programmation, ils m'ont aidé à déboguer de nombreux bugs. Est-ce mauvais de faire de la publicité comme ça dans segmentfault ?

Résumé

Référence :


  1. Comment créer plusieurs requêtes de clause Where à l'aide Laravel Eloquent ? >

    Partage de l'implémentation PHP du code séquence de Fibonacci
  2. Explication de l'implémentation PHP de la fonction de recherche de tableau basée sur la méthode de bissection

Explication détaillée des classes et des objets en php



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