Laravel 중첩 관계 문제: 복잡한 데이터 검색 해결
Laravel에서는 데이터베이스 테이블 간의 복잡한 관계를 연결하는 것이 종종 어려울 수 있습니다. ID를 기준으로 이벤트 참석자를 검색하려는 시나리오를 생각해 보세요. 그러나 이 작업은 이벤트-사람 관계 체인 내에 중간 테이블이 있기 때문에 복잡합니다.
이 문제를 해결하려면 모델 간의 관계를 꼼꼼하게 정의하는 것이 중요합니다. 관련 모델 관계는 다음과 같습니다.
이벤트 모델:
class Event extends Eloquent { public function city() { return $this->belongsTo('City'); } }
도시 모델:
class City extends Eloquent { public function companies() { return $this->hasMany('Company'); } }
회사 모델:
class Company extends Eloquent { public function persons() { return $this->hasMany('Person'); } }
사람 모델:
class Person extends Eloquent { public function eventscore() { return $this->belongsToMany('Event', 'event_scores', 'person_id', 'event_id')->withPivot('score')->withTimestamps(); } }
이러한 관계를 정의한 후 문제 해결을 위한 두 가지 실패한 시도를 살펴보겠습니다.
return Event::with('city')->with('company')->get();
return Event::with('city')->whereHas('companies', function($query) use ($company_id){ $query->where('company_id', $company_id); })->get();
궁극적인 해결책은 eloquent의 Eager Loading을 활용하는 것입니다. 기능:
return Event::with('city.companies.persons')->get();
이 쿼리는 관련 도시, 회사 및 해당 회사와 관련된 사람과 함께 이벤트를 검색합니다.
또는 사람 테이블의 특정 필드만 필요한 경우 :
return Event::with(['city.companies.persons' => function ($query) { $query->select('id', '...'); }])->get();
위 내용은 Laravel에서 중첩 관계가 있는 이벤트 참석자를 효율적으로 검색하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!