Consultas a la Relación
Comprar curso

102. Consultas a la Relación

En este capítulo, aprenderás cómo hacer consultas a la relación en Laravel 10. Descubre cómo utilizar los métodos de consulta para recuperar los datos relacionados de uno o varios modelos de la base de datos.


2 comentarios

Inicia sesión para comentar

Comentarios:

  • Victor Arana Flores

    Victor Arana Flores hace 1 año Destacado

    En Laravel 10, las relaciones entre modelos de la base de datos permiten recuperar datos relacionados de forma sencilla y eficiente. Una vez definida la relación, podemos utilizar los métodos de consulta para recuperar los datos que necesitamos.

    Si queremos recuperar los datos relacionados de un solo modelo, podemos utilizar el método with() en una consulta. Este método acepta como argumento el nombre de la relación y carga los datos relacionados junto con el modelo original. Por ejemplo, si tenemos un modelo User con una relación posts() a través del modelo Post, podemos cargar los datos relacionados de la siguiente manera:

    $user = User::with('posts')->find(1);

    Este código carga los posts relacionados del usuario con ID 1. Podemos acceder a los datos relacionados utilizando la propiedad posts del modelo:

    foreach ($user->posts as $post) {
       echo $post->title;
    }

    Si queremos hacer una consulta que incluya los datos relacionados de varios modelos, podemos encadenar los métodos with() y where() en la consulta. Por ejemplo, si tenemos un modelo User con una relación posts() a través del modelo Post, y un modelo Comment con una relación user() a través del modelo User, podemos cargar los datos relacionados de esta manera:

    $comments = Comment::with('user.posts')
                   ->where('created_at', '>', Carbon::now()->subDays(7))
                   ->get();

    Este código carga los usuarios y sus posts relacionados para los comentarios creados hace menos de 7 días. Podemos acceder a los datos relacionados de la misma manera que en el ejemplo anterior:

    foreach ($comments as $comment) {
       echo $comment->user->name;
       echo $comment->user->posts->count();
    }

    En resumen, en Laravel 10 podemos hacer consultas a las relaciones utilizando los métodos with() y encadenando otros métodos de consulta según nuestras necesidades. Esto nos permite recuperar los datos relacionados de forma eficiente y utilizarlos en nuestra aplicación.

  • Hernán Ramirez Saavedra

    Hernán Ramirez Saavedra hace 9 meses

    Victor me sale que la clase no existe en el tinker, me pasa para todo menos para user, cual puede ser el error por favor :/

    • Victor Arana Flores hace 9 meses

      Hola, coloca primero use App\Models\User