로컬 범위에서 Eloquent의 다중 조인
Eloquent와 스코프 기능에 관한 질문이 있습니다 :
두 가지 범위를 가정합니다.
class Result extends Model {
public function scopeIsRace($query) { return $query
->join('sessions', 'sessions.id', '=', 'results.session_id')
->where('sessions.type', 10)
}
public function scopeIsOfficial($query) { return $query
->join('sessions', 'sessions.id', '=', 'results.session_id')
->join('events', 'events.id', '=', 'sessions.event_id')
->where('events.regular_event', 1);
}
}
둘 다 호출하면 두 개의 세션 조인이 수행되고 결과 쿼리는 다음과 같이 보입니다 (작동하지 않음)
select * from `results` inner join `sessions` on `sessions`.`id` = `results`.`session_id` inner join `sessions` on `sessions`.`id` = `results`.`session_id` inner join `events` on `events`.`id` = `sessions`.`event_id` where `driver_id` = 24 and (`sessions`.`type` = 10 or `sessions`.`type` = 11) and `events`.`regular_event` = 1
세션에서 이중 참여를 방지하려면 어떻게합니까?
답변
1 Siggi
@Nima 정말 감사합니다. 고급 whereHas에 대해 완전히 잊으십시오. 제안 된 질문 에서 구조를 사용했으며 완벽하게 작동합니다.
public function scopeIsRace($query) { return $query->whereHas('session', function($query){ $query->where('type', 10);
});
}
public function scopeIsOfficial($query) { return $query->whereHas('session', function($query) { return $query->whereHas('event', function($query2) { $query2->where('regular_event', 1);
});
});
}