Mysql
 sql >> Datenbank >  >> RDS >> Mysql

Laravel / Eloquent:verschachteltes WhereHas

Als Ihre $skills Variable ein Array zu sein scheint, könnten Sie das Eloquent whereIn verwenden Funktion.

$workers = Worker::whereHas('skills', function (Builder $query) use ($skills) {
    $query->whereIn('name', $skills);
})->get();

Aktualisieren

Das Folgende sollte Ihnen eine Sammlung von Workers liefern die alle Skills haben .

$workers = Worker::whereHas('skills');

foreach ($skills as $skill) {
    $workers->whereHas('skills', function (Builder $query) use ($skill) {
        $query->where('name', $skill);
    })->get();
}

$workers->get();