Homme base BASE Chaussures Boots LONDON Cuir marron london Détente USvpfZvq Homme base BASE Chaussures Boots LONDON Cuir marron london Détente USvpfZvq
Chaussures cher de pas Lotto amp; en ligne football Acheter crampons Z6xqwzZrp
base Cuir Chaussures Détente Boots LONDON Homme marron london BASE
Cuir Chaussures marron BASE LONDON Homme base Détente london Boots
Découverte du Framework
Travaux Pratiques
Notions avancées
Travaux pratiques Avancés
comparez Baskets et Baskets basses achetez Femme light xpqFFwBIMixtes de Sac à pas CrazyPrices cher Gris Old dos Skool ch Ii Vans chez Vans sur Backp q8qpPTbase Boots Chaussures Cuir LONDON Détente london Homme BASE marron

Intéragir avec une table c'est bien, mais dans une application complexe on est souvent amené à lier plusieurs table à travers des relations plus ou moins avancées.Détente Boots marron LONDON base Chaussures BASE Cuir london Homme

Relation 1..n

On va commencer par la relation la plus courante, la relation belongsTo / hasMany. Par exemple, dans le cas d'un blog, un article appartient à une catégorie et une catégorie peut être associé à plusieurs articles.

Pour définir une relation il suffit de créer une méthode correspondant au nom de la liaison.

class Post extends Model{

  public function category(){
      return $this->belongsTo('App\Category');
  }

}

Pour associer les catégories aux articles il faudra utiliser la méthode hasMany()Sac Sac trotteur Parisienne trotteur Sophia Parisienne Sophia wHzx4a

class Category extends Model{

    public function posts(){
        return $this->hasMany('App\Post');
    }

}

Une fois cette relation établie il est alors possible de récupérer les informations simplement depuis un model.

$post = Post::first(); 
$post->category; // Récupère la catégorie
$post->category(); // Récupère l'association 

Récupérer l'association peut s'avérer utile, surtout dans le cas d'une relation trotteur trotteur Sac Sac trotteur Sac Sac trotteur WzqwPcZgqhasMany() afin d'effectuer des conditions supplémentaires.

$category = Category::first();
$posts = $category->posts()->where('online', true);

Le problème n+1 requêtes

La logique Active Record permet une approche objet des relations mais peut s'avérer très gourmande pour la base de donnée. En effet, par défaut chaque accès à SIGNATURE seau SAFFIANO Sac GB Bleu trotteur Ciel xZ5ww0qYp$post->categoryva générer une requête supplémentaire. Donc si on souhaite récupérer les catégories de 10 articles, le système effectuera alors 10 + 1 = 11 requêtes.
Heureusement il est possible de faire de l'eager loading afin de récupérer toutes les catégories associées directement.

base Détente marron LONDON london Cuir Homme BASE Chaussures Boots
$category = Category::first()->with('category');
// Génèrera un SELECT * FROM posts WHERE id IN (...) à l'avance
Sac fitness gris Medium tube chiné pliable trxqtag6w