Maison > base de données > tutoriel mysql > Comment récupérer des données imbriquées à partir de modèles éloquents dans Laravel : un guide pratique

Comment récupérer des données imbriquées à partir de modèles éloquents dans Laravel : un guide pratique

Linda Hamilton
Libérer: 2024-11-17 03:29:03
original
693 Les gens l'ont consulté

How to Retrieve Nested Data from Eloquent Models in Laravel: A Practical Guide

Relations imbriquées de Laravel : démêler la récupération de données complexes

L'une des forces de Laravel réside dans sa capacité à gérer des relations complexes entre les modèles. Cependant, récupérer des données imbriquées peut parfois s’avérer difficile. Dans cet article, nous aborderons un problème courant impliquant une relation profondément imbriquée et démontrerons comment obtenir le résultat souhaité avec le puissant ORM de Laravel.

Supposons que vous ayez un scénario dans lequel vous devez récupérer une liste de personnes qui vous êtes abonné à un événement spécifique. L'événement, quant à lui, est lié à une ville, tandis que la ville est associée à une ou plusieurs entreprises. Enfin, chaque entreprise emploie plusieurs personnes.

Pour résoudre cette relation imbriquée, évitez d'utiliser une requête SQL brute car elle peut entraîner des pénalités de performances et des problèmes de maintenance. Au lieu de cela, exploitons les relations éloquentes de Laravel.

// Event Model
class Event extends Eloquent
{
    public function city()
    {
        return $this->belongsTo('City');
    }
}
Copier après la connexion
// City Model
class City extends Eloquent
{
    public function companies()
    {
        return $this->hasMany('Company');
    }
}
Copier après la connexion
// Company Model
class Company extends Eloquent
{
    public function persons()
    {
        return $this->hasMany('Person');
    }
}
Copier après la connexion
// Person Model
class Person extends Eloquent
{
    public function company()
    {
        return $this->belongsTo('Company');
    }
}
Copier après la connexion

La requête correcte pour récupérer les données imbriquées souhaitées est :

Event::with('city.companies.persons')->get();
Copier après la connexion

En utilisant le " with()", vous pouvez spécifier les modèles associés que vous souhaitez récupérer avec le modèle principal. Dans ce cas, nous précisons que nous souhaitons récupérer la relation "ville", suivie de la relation "entreprises", et enfin la relation "personnes" associée à chaque entreprise.

Le résultat de cette requête sera une collection Eloquent qui contient des modèles d'événements, chacun ayant accès à ses modèles de ville, d'entreprises et de personnes correspondants.

// To retrieve specific fields from the persons table
Event::with(['city.companies.persons' => function ($query) {
    $query->select('id', '...');
}])->get();
Copier après la connexion

En incorporant cette technique dans votre application Laravel, vous pouvez simplifier la récupération des éléments profondément imbriqués données, garantissant un code maintenable et efficace.

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal