Mysql
 sql >> Base de données >  >> RDS >> Mysql

Laravel / Eloquent :WhereHas imbriqué

En tant que vos $skills variable semble être un tableau, vous pouvez utiliser le whereIn Eloquent fonction.

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

Mettre à jour

Ce qui suit devrait vous donner une collection de Workers qui ont toutes les Skills .

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

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

$workers->get();