Eloquent Trick: 하위 쿼리의 Laravel 모델

WBOY
풀어 주다: 2024-08-17 06:50:06
원래의
499명이 탐색했습니다.

Eloquent Trick: Laravel Model from Subquery

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿