Maison  >  Article  >  base de données  >  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
Linda Hamiltonoriginal
2024-11-17 03:29:03613parcourir

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');
    }
}
// City Model
class City extends Eloquent
{
    public function companies()
    {
        return $this->hasMany('Company');
    }
}
// Company Model
class Company extends Eloquent
{
    public function persons()
    {
        return $this->hasMany('Person');
    }
}
// Person Model
class Person extends Eloquent
{
    public function company()
    {
        return $this->belongsTo('Company');
    }
}

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

Event::with('city.companies.persons')->get();

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();

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!

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