Laravel에서는 다음과 같은 테이블 속성을 사용하여 모델의 해당 테이블을 정의하는 것이 일반적입니다.
class User extends Model { protected $table = 'users'; }그러나 테이블에 직접 매핑하는 대신 하위 쿼리를 사용할 수 있습니다. 이 기술을 사용하면 데이터베이스 뷰를 생성하는 것과 유사하지만 Eloquent 작업의 유연성이 추가되어 애플리케이션 계층 내에서 복잡한 쿼리를 캡슐화할 수 있습니다.
예를 들어 관리자와 일반 사용자 모두에 대한 정보를 저장하는 사용자 테이블을 생각해 보세요. 하위 쿼리를 사용하여 AdminUser 모델을 만들 수 있습니다:
class User extends Model { protected $table = 'users'; }이 모델은 하위 쿼리(admin_user = 1인 사용자의 ID, 이름 선택)에서 데이터를 가져오므로 표준 모델처럼 쿼리할 수 있습니다.
class User extends Model { protected $table = 'users'; }또는
class User extends Model { protected $table = 'users'; }그러나 find(1)와 같은 특정 쿼리는 직접 작동하지 않는다는 점에 유의하세요.
class User extends Model { protected $table = 'users'; }이 문제를 해결하려면 first():
와 결합된 where 조건을 사용할 수 있습니다.
class User extends Model { protected $table = 'users'; }결론
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3