Maison >développement back-end >tutoriel php >Compétences Laravel : explication de la méthode d'appel de chaîne de superposition de Query Builder
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 chargeIntroduction
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ébutif($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 = 2Bien 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
Résumé
Référence :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!