はじめに
Laravelでリレーション先に紐づくデータが存在するものだけを取得したい時ってありませんか?
例えば学生を保存するテーブルと所属する部活を保存しているテーブルがあったとします。
このときに、何らかの部活に所属している学生だけを取得したい!
そんなときです。似たようなケースがあったのでその時の解決方法をメモします。
例
以下のような学生テーブルのモデルと部活所属テーブルのモデルがあるとします。
1 2 3 4 5 6 7 8 | class Student extends Model { // 学生と所属する部活の関係 public function club() { return $this->hasMany('App\Eloquent\BelongsClub'); } } |
1 2 3 4 5 6 7 | class BelongsClub extends Model { public function belongsStudent() { return $this->belongsTo('App\Eloquent\Student'); } } |
これは学生と部活が1対多であることを示しています。
このような場合に部活に所属している学生だけを取得します。
方法
以下のようにwhereHasとwhereExistsを組み合わせることで取得できます。
1 2 3 4 5 6 | Student::with('club') ->whereHas('club', function ($query) { $query->whereExists(function ($query) { return $query; }) ->get(); |
withの引数はリレーション先を指定しているStudentクラスのメソッド名です。
whereExistsでリレーション先が存在するものだけに絞り込んでいます。
以上です。