Le groupe Laravel interroge les premiers enregistrements
Dans Laravel, nous devons souvent interroger les premiers enregistrements de la base de données, par exemple interroger les cinq produits les plus vendus dans une catégorie de produits. Dans ce cas, nous utilisons généralement des requêtes de regroupement pour y parvenir.
Cet article expliquera comment effectuer une requête de groupe dans Laravel et interroger les premiers enregistrements de chaque groupe.
- Préparation
Tout d'abord, nous devons disposer d'un tableau de données pour stocker les informations sur le produit. Supposons que nous ayons créé un tableau de données appelé « produits » et que nous y ayons inséré des données.
- Écrire des instructions de requête
Nous pouvons utiliser le générateur de requêtes de Laravel pour écrire des instructions de requête. Tout d’abord, nous devons regrouper les produits par catégorie, puis interroger les cinq principaux produits de chaque groupe. L'instruction de requête est la suivante :
$products = DB::table('products') ->select('category', DB::raw('MAX(sales) as max_sales')) ->groupBy('category') ->orderByDesc('max_sales') ->limit(5) ->get();
Ici, nous utilisons la méthode select() pour spécifier les champs à interroger, et la méthode DB::raw() pour calculer le volume de ventes maximum de chaque groupe. La méthode groupBy() spécifie le regroupement par champs de catégorie, la méthode orderByDesc() trie par ventes maximales par ordre décroissant et la méthode limit() limite le nombre d'enregistrements interrogés à 5. Enfin, utilisez la méthode get() pour exécuter la requête et renvoyer un ensemble de résultats avec la catégorie comme clé et le volume de ventes maximum comme valeur.
- Traitement des résultats de la requête
Ensuite, nous devons traiter les résultats de la requête pour obtenir les cinq meilleurs produits de chaque groupe. Nous pouvons traiter l'ensemble de résultats dans une boucle, interroger les cinq premiers éléments de chaque groupe et les ajouter à un nouveau tableau.
$result = []; foreach ($products as $product) { $query = DB::table('products') ->select('*') ->where('category', $product->category) ->orderByDesc('sales') ->limit(5) ->get(); $result[$product->category] = $query; }
Dans la boucle, nous interrogeons d'abord tous les produits de chaque catégorie, puis trions par volume de ventes par ordre décroissant, limitons le nombre d'enregistrements de requête à 5 et enfin ajoutons les résultats de la requête à un nouveau tableau. Une fois la boucle terminée, nous obtenons un nouveau tableau avec la catégorie comme clé et le résultat de la requête comme valeur. Ce tableau contient les cinq produits les plus vendus dans chaque catégorie.
- Résultats de sortie
Enfin, nous pouvons parcourir le nouveau tableau et afficher les résultats de la requête sur la page.
foreach ($result as $category => $products) { echo '<h3>'.$category.'</h3>'; echo '<ul>'; foreach ($products as $product) { echo '<li>' . $product->name . '</li>'; } echo '</ul>'; }
Lors de la sortie des résultats, nous affichons d'abord le nom de la catégorie, puis nous affichons le nom de chaque produit dans une liste ul.
- Résumé
Dans cet article, nous avons présenté comment utiliser une requête groupée dans Laravel pour interroger les premiers enregistrements de chaque groupe. En utilisant select(), groupBy(), orderByDesc(), limit() et d'autres méthodes, nous pouvons écrire de manière flexible des instructions de requête pour répondre à diverses exigences de requête complexes. Dans le même temps, nous avons également appris à utiliser le générateur de requêtes de Laravel pour écrire des instructions de requête de base de données, ainsi que pour traiter et afficher les résultats des requêtes.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

L'article discute de la création et de la personnalisation des éléments d'interface utilisateur réutilisables dans Laravel à l'aide de composants, offrant les meilleures pratiques pour l'organisation et suggérant des packages améliorant.

Cet article détaille la mise en œuvre d'authentification et d'autorisation OAuth 2.0 dans Laravel. Il couvre à l'aide de packages comme les solutions de ligue / oauth2-serveur ou spécifiques au fournisseur, mettant l'accent sur la configuration de la base de données, l'enregistrement du client, la configuration du serveur d'autorisation

L'article traite des meilleures pratiques pour déployer Laravel dans des environnements natifs du cloud, en se concentrant sur l'évolutivité, la fiabilité et la sécurité. Les problèmes clés incluent la conteneurisation, les microservices, la conception sans état et les stratégies d'optimisation.

L'article discute de la création et de l'utilisation des directives de lame personnalisées à Laravel pour améliorer les modèles. Il couvre la définition des directives, les utilisant dans des modèles et les gérer dans de grands projets, mettant en évidence des avantages tels que l'amélioration de la réutilisabilité du code et R

L'article discute de la création et de l'utilisation de règles de validation personnalisées dans Laravel, offrant des étapes pour les définir et les mettre en œuvre. Il met en évidence des avantages tels que la réutilisabilité et la spécificité et fournit des méthodes pour étendre le système de validation de Laravel.

Cet article explore des stratégies optimales de téléchargement de fichiers et de stockage cloud dans Laravel. Il examine le stockage local vs fournisseurs de cloud (AWS S3, Google Cloud, Azure, DigitalOcean), mettant l'accent sur la sécurité (validation, désinfection, HTTPS) et Performance Opti

La console artisanale de Laravel automatise des tâches comme la génération de code, l'exécution de migrations et la planification. Les commandes clés incluent la marque: contrôleur, migrer et db: graines. Les commandes personnalisées peuvent être créées pour des besoins spécifiques, améliorant l'efficacité du flux de travail.

L'article discute de l'utilisation du routage de Laravel pour créer des URL conviviales, couvrant les meilleures pratiques, des URL canoniques et des outils pour l'optimisation du référencement. Nombre de mots: 159
