"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > Eloquent Trick: 하위 쿼리의 Laravel 모델

Eloquent Trick: 하위 쿼리의 Laravel 모델

2024-11-03에 게시됨
검색:595

Eloquent Trick: Laravel Model from Subquery

Laravel에서는 다음과 같은 테이블 속성을 사용하여 모델의 해당 테이블을 정의하는 것이 일반적입니다.

클래스 사용자 확장 모델 { 보호된 $table = '사용자'; }
class User extends Model {
  protected $table = 'users';
}
그러나 테이블에 직접 매핑하는 대신 하위 쿼리를 사용할 수 있습니다. 이 기술을 사용하면 데이터베이스 뷰를 생성하는 것과 유사하지만 Eloquent 작업의 유연성이 추가되어 애플리케이션 계층 내에서 복잡한 쿼리를 캡슐화할 수 있습니다.

예를 들어 관리자와 일반 사용자 모두에 대한 정보를 저장하는 사용자 테이블을 생각해 보세요. 하위 쿼리를 사용하여 AdminUser 모델을 만들 수 있습니다:


클래스 AdminUser { 공개 함수 getTable(): 문자열|\Illuminate\Contracts\Database\Query\Expression { $sql = 사용자::쿼리() ->select('ID', '이름') ->어디('admin_user', true) ->toRawSql(); return DB::raw(sprintf('(%s) as admin_users', $sql)); } }
class User extends Model {
  protected $table = 'users';
}
이 모델은 하위 쿼리(admin_user = 1인 사용자의 ID, 이름 선택)에서 데이터를 가져오므로 표준 모델처럼 쿼리할 수 있습니다.


AdminUser::query()->get();
class User extends Model {
  protected $table = 'users';
}
또는


AdminUser::query()->first();
class User extends Model {
  protected $table = 'users';
}
그러나 find(1)와 같은 특정 쿼리는 직접 작동하지 않는다는 점에 유의하세요.


AdminUser::query()->find(1);
class User extends Model {
  protected $table = 'users';
}
이 문제를 해결하려면 first():

와 결합된 where 조건을 사용할 수 있습니다.

AdminUser::query()->where('id', 1)->first();
class User extends Model {
  protected $table = 'users';
}
결론

제공된 예는 모델 내에서 논리를 구성하는 방법을 간단하게 보여줍니다. 그러나 이 접근 방식은 훨씬 더 복잡한 시나리오를 수용하도록 확장 및 조정할 수 있습니다. 이러한 구조를 활용함으로써 복잡한 논리를 효율적으로 관리하고 추출할 수 있으므로 모델이 복잡해짐에 따라 체계화되고 유지 관리 및 확장 가능한 상태를 유지할 수 있습니다.

릴리스 선언문 이 기사는 https://dev.to/bedram-tamang/eloquent-trick-laravel-model-from-subquery-4im6?1에서 복제됩니다.1 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3