chrislentz

chrislentz

Member Since 6 Years Ago

Experience Points
12,440
Total
Experience

2,560 experience to go until the next level!

In case you were wondering, you earn Laracasts experience when you:

  • Complete a lesson — 100pts
  • Create a forum thread — 50pts
  • Reply to a thread — 10pts
  • Leave a reply that is liked — 50pts
  • Receive a "Best Reply" award — 500pts
Lessons Completed
137
Lessons
Completed
Best Reply Awards
1
Best Reply
Awards
  • start your engines Created with Sketch.

    Start Your Engines

    Earned once you have completed your first Laracasts lesson.

  • first-thousand Created with Sketch.

    First Thousand

    Earned once you have earned your first 1000 experience points.

  • 1-year Created with Sketch.

    One Year Member

    Earned when you have been with Laracasts for 1 year.

  • 2-years Created with Sketch.

    Two Year Member

    Earned when you have been with Laracasts for 2 years.

  • 3-years Created with Sketch.

    Three Year Member

    Earned when you have been with Laracasts for 3 years.

  • 4-years Created with Sketch.

    Four Year Member

    Earned when you have been with Laracasts for 4 years.

  • 5-years Created with Sketch.

    Five Year Member

    Earned when you have been with Laracasts for 5 years.

  • school-in-session Created with Sketch.

    School In Session

    Earned when at least one Laracasts series has been fully completed.

  • welcome-newcomer Created with Sketch.

    Welcome To The Community

    Earned after your first post on the Laracasts forum.

  • full-time-student Created with Sketch.

    Full Time Learner

    Earned once 100 Laracasts lessons have been completed.

  • pay-it-forward Created with Sketch.

    Pay It Forward

    Earned once you receive your first "Best Reply" award on the Laracasts forum.

  • subscriber Created with Sketch.

    Subscriber

    Earned if you are a paying Laracasts subscriber.

  • lifer Created with Sketch.

    Lifer

    Earned if you have a lifetime subscription to Laracasts.

  • evangelist Created with Sketch.

    Laracasts Evangelist

    Earned if you share a link to Laracasts on social media. Please email [email protected] with your username and post URL to be awarded this badge.

  • chatty-cathy Created with Sketch.

    Chatty Cathy

    Earned once you have achieved 500 forum replies.

  • lara-veteran Created with Sketch.

    Laracasts Veteran

    Earned once your experience points passes 100,000.

  • 10k-strong Created with Sketch.

    Ten Thousand Strong

    Earned once your experience points hits 10,000.

  • lara-master Created with Sketch.

    Laracasts Master

    Earned once 1000 Laracasts lessons have been completed.

  • laracasts-tutor Created with Sketch.

    Laracasts Tutor

    Earned once your "Best Reply" award count is 100 or more.

  • laracasts-sensei Created with Sketch.

    Laracasts Sensei

    Earned once your experience points passes 1 million.

  • top-50 Created with Sketch.

    Top 50

    Earned once your experience points ranks in the top 50 of all Laracasts users.

Level 3
12,440 XP
Oct
12
2 weeks ago
Activity icon

Replied to How Can You Get One Random Result From A "morphedByMany" Relationship?

@bobbybouwmann When I run the second one, I only get a single result. Not one per genre, but one total.

/app/Models/Genre.php

public function randomMovie()
{
    return $this->morphedByMany('App\Models\Movie', 'genreable', 'cnt_genres');
}
/app/Http/Controllers/GenreController.php

$genres = Genre::with(['randomMovie' => function ($q) {
    return $q->inRandomOrder()->limit(1);
}, 'randomMovie.poster'])->orderBy('name', 'ASC')->get();
select * from `genres` order by `name` asc;

select `movies`.*, `cnt_genres`.`genre_id` as `pivot_genre_id`, `cnt_genres`.`genreable_id` as `pivot_genreable_id`, `cnt_genres`.`genreable_type` as `pivot_genreable_type` from `movies` inner join `cnt_genres` on `movies`.`id` = `cnt_genres`.`genreable_id` where `cnt_genres`.`genre_id` in (1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18) and `cnt_genres`.`genreable_type` = 'App\Models\Movie' order by RAND() limit 1;
Oct
11
2 weeks ago
Activity icon

Started a new Conversation How Can You Get One Random Result From A "morphedByMany" Relationship?

I have a many-to-many (polymorphic) relationship. Movies have many genres and genres have many movies. The relationship I have setup works great, but I am trying to figure out how I can select one random movie for each genre via Eloquent.

I have tried a couple of different things but haven't had any luck yet.

/app/Models/genre.php

public function randomMovie()
{
    return $this->morphedByMany('App\Models\Movie', 'genreable', 'cnt_genres')->has('poster')->orderBy(DB::raw('RAND()'))->take(1);
}
/app/Http/Controllers/GenreController.php

$genres = Genre::with(['randomMovie' => function ($q) {
    return $q->inRandomOrder()->limit(1);
}, 'randomMovie.poster'])->orderBy('name', 'ASC')->get();