Laravel에서는 다음과 같은 table 속성을 사용하여 모델의 해당 테이블을 정의하는 것이 일반적입니다.
class User extends Model { protected $table = 'users'; }
그러나 테이블에 직접 매핑하는 대신 하위 쿼리를 사용할 수 있습니다. 이 기술을 사용하면 데이터베이스 뷰를 생성하는 것과 유사하지만 Eloquent 작업의 유연성이 추가되어 애플리케이션 계층 내에서 복잡한 쿼리를 캡슐화할 수 있습니다.
예를 들어 관리자와 일반 사용자 모두에 대한 정보를 저장하는 사용자 테이블을 생각해 보세요. 하위 쿼리를 사용하여 AdminUser 모델을 생성할 수 있습니다:
class AdminUser { public function getTable(): string|\Illuminate\Contracts\Database\Query\Expression { $sql = User::query() ->select('id', 'name') ->where('admin_user', true) ->toRawSql(); return DB::raw(sprintf('(%s) as admin_users', $sql)); } }
이 모델은 하위 쿼리(admin_user = 1인 사용자에서 ID, 이름 선택)에서 데이터를 가져오므로 표준 모델처럼 쿼리할 수 있습니다.
AdminUser::query()->get();
또는
AdminUser::query()->first();
그러나 find(1)와 같은 특정 쿼리는 직접 작동하지 않는다는 점에 유의하세요.
AdminUser::query()->find(1);
이 문제를 해결하려면 where 조건을 first()와 결합하여 사용할 수 있습니다.
AdminUser::query()->where('id', 1)->first();
제공된 예는 모델 내에서 논리를 구성하는 방법을 간단하게 보여줍니다. 그러나 이 접근 방식은 훨씬 더 복잡한 시나리오를 수용하도록 확장 및 조정할 수 있습니다. 이러한 구조를 활용함으로써 복잡한 논리를 효율적으로 관리하고 추출할 수 있으므로 모델이 복잡해짐에 따라 체계화되고 유지 관리 및 확장 가능한 상태를 유지할 수 있습니다.
위 내용은 Eloquent Trick: 하위 쿼리의 Laravel 모델의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!