Laravel의 Eloquent에서 하위 쿼리를 사용하는 방법은 무엇입니까?
Laravel Eloquent는 Clauses의 Select, From From, Where 및 Order의 하위 쿼리를 지원하여 원시 SQL없이 유연한 데이터 검색을 가능하게합니다. 1. selectSub ()를 사용하여 사용자 당 Post Count와 같은 계산 된 열을 추가하십시오. 2. ()에서 fromsub ()를 사용하여 ()에서 하위 쿼리를 그룹화 된 데이터에 대한 파생 된 테이블로 취급합니다. 3. 관련 데이터를 기반으로 조건부 필터링을 위해 WhereExists (), wherenotexists () 또는 스칼라 하위 쿼리를 사용하십시오. 4. 최신 사후 날짜에 따라 주문한 사용자와 같은 관련 레코드의 값별로 정렬하기 위해 하위 쿼리를 직접 OrderBy ()로 전달합니다. 컬럼 비교의 경우 항상 Wherecolumn ()을 선호하고 조인 또는 열렬한 하중과 같은 대안을 평가하여 대형 데이터 세트에 대한 성능 영향을 고려하십시오.
Laravel의 Eloquent에서 하위 쿼리를 사용하면 하나의 쿼리를 다른 쿼리에 포함시킬 수 있으며, 이는 관련 또는 동일한 테이블의 데이터를 기반으로 필터, 선택 또는 주문 결과를 필터링, 선택 또는 주문할 때 유용합니다. 쿼리 빌더 위에 구축 된 Laravel의 웅변적인 ORM은 Laravel 5.6에서 시작하여 조항 ORDER BY
SELECT
, FROM
From Where 및 WHERE
의 하위 쿼리를 지원합니다.

웅변에서 하위 쿼리를 효과적으로 사용하는 방법은 다음과 같습니다.
1. SELECT 절의 하위 쿼리
하위 쿼리를 사용하여 결과에 계산되거나 집계 된 열을 추가하십시오.

Illuminate \ Database \ Query \ expression을 사용하십시오. $ user = user :: select ( 'user.*', new Expression ( '('.). post :: selectraw ( 'count (*)') -> wherecolumn ( 'posts.user_id', 'user.id') -> TOSQL () . ') post_count as' ))) -> addbinding (post :: selectraw ( 'count (*)') -> wherecolumn ( 'posts.user_id', 'user.id') -> getBindings (), 'select') -> get ();
또는 더 나은 : 클리너 구문에 selectSub()
사용하십시오.
$ user = user :: selectSub ( post :: wherecolumn ( 'posts.user_id', 'user.id')-> selectraw ( 'count (*)'), 'post_count' )-> get ();
✅ 각 사용자에게
post_count
필드를 추가하여 게시물을 계산합니다.
2. Clause에서의 하위 쿼리 (하위 쿼리 조인)
하위 쿼리를 FROM
Clause의 파생 테이블로 사용하십시오.
$ likesposts = post :: select ( 'user_id', db :: raw ( 'max (created_at) as astic_post_date'))) -> groupBy ( 'user_id'); $ user = user :: fromSub ($ hickesposts, 'lickes_posts') -> 조인 -> get ();
또는 폐쇄와 함께 from()
사용하십시오.
$ user = db :: table (function ($ query) { $ query-> select ( 'user_id', db :: raw ( 'max (created_at) as last_post'))) -> from ( 'posts') -> groupBy ( 'user_id'); }, '최신_posts') -> 조인 -> select ( 'users.name', 'lickes_posts.last_post') -> get ();
✅ 기본 테이블로 그룹화 또는 필터링 된 데이터로 작업해야 할 때 유용합니다.
3. 위치 조항의 하위 정체
하위 쿼리를 사용하여 값을 조건부로 비교하십시오.
$ user = user :: 여기서 ( 'id', '! =', function ($ query) { $ query-> from ( '사용자') -> selectraw ( 'max (id)'); // 최신 사용자를 제외하십시오 })-> get ();
보다 실용적인 예 : 한 달 전에 최신 게시물이있는 사용자를 얻습니다.
$ user = user :: whereExists (function ($ query) { $ query-> select (db :: raw (1)) -> from ( 'posts') -> wherecolumn ( 'posts.user_id', 'user.id') -> 여기서 ( 'posts.created_at', '>', now ()-> submonth ()); })-> get ();
또는 스칼라 하위 쿼리를 사용하십시오.
$ lastloginthreshold = now ()-> 서브 데일 (30); $ inactiveUsers = user :: where (function ($ query) 사용 ($ lastloginthreshold) { $ query-> where ( 'last_login', '<', $ lastloginthreshold) -> orwherenull ( 'last_login'); }) -> 여기서 ( 'id', 'in', function ($ q) { $ q-> select ( 'user_id') -> from ( 'posts') -> where ( 'create_at', '>', now ()-> subyear ()); })-> get ();
whereExists
,whereNotExists
또는 Scalar 비교를 사용하십시오.
4. 절에 의한 순서의 하위 쿼리
하위 쿼리를 사용하여 관련 테이블의 값을 기준으로 한 주문 결과.
예 : 최신 게시물의 생성 날짜까지 사용자를 주문하십시오.
$ user = user :: OrderByDesc ( Post :: select ( 'create_at') -> wherecolumn ( 'posts.user_id', 'user.id') -> 최신 () -> 한도 (1) )-> get ();
또는 더 명시 적으로 :
$ user = user :: select ( 'user.*') -> OrderByDesc ( post :: wherecolumn ( 'posts.user_id', 'user.id') -> selectraw ( 'max (create_at)') )) -> get ();
✅ 이는 결합 및 그룹화를 피하고 인덱스와 잘 어울립니다.
주요 팁
- 기본 쿼리와 하위 쿼리 사이의 열을 비교할 때는 항상
whereColumn()
사용하십시오. - 클리너, 더 읽기 쉬운 코드에는
selectSub()
및fromSub()
사용하십시오. - 성능에주의하십시오. 대형 데이터 세트에서는 보수가 느려질 수 있습니다. 결합 또는 적절한 경우 열렬한 로딩을 고려하십시오.
- 원시 하위 쿼리를 사용할 때는 필요한 경우 매개 변수를 수동으로 바인딩하는 것을 잊지 마십시오 (Laravel은 종종 이것을 처리합니다).
기본적으로 Laravel은 하위 쿼리를 관리 가능하고 표현력을 발휘합니다. 관련 데이터를 기반으로 선택, 필터링 또는 정렬에 관계없이 웅변의 하위 쿼리는 대부분의 경우 원시 SQL로 떨어지지 않고 유연성을 제공합니다.
위 내용은 Laravel의 Eloquent에서 하위 쿼리를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undress AI Tool
무료로 이미지를 벗다

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel의 구성 캐시는 모든 구성 파일을 단일 캐시 파일로 병합하여 성능을 향상시킵니다. 생산 환경에서 구성 캐시를 활성화하면 각 요청에서 I/O 운영 및 파일 구문 분석이 줄어들어 구성로드 속도를 높일 수 있습니다. 1. 응용 프로그램을 배포 할 때 활성화되어야하며 구성이 안정적이며 자주 변경되지 않아야합니다. 2. 활성화 후 구성을 수정 한 후 PhPartisAnconfig를 다시 실행해야합니다. 3. 구성 파일의 런타임 조건에 의존하는 동적 로직 또는 클로저를 사용하지 마십시오. 4. 문제 해결 문제가 발생하면 먼저 캐시를 지우고 .env 변수를 확인하고 다시 캐시해야합니다.

Laravel의 eloquentscopes는 로컬 범위와 글로벌 범위로 나뉘어져있는 공통 쿼리 로직을 캡슐화하는 도구입니다. 1. 로컬 범위는 스코프로 시작하는 메소드로 정의되며 Post :: published (); 2. 글로벌 범위는 모든 쿼리에 자동으로 적용되며 종종 소프트 삭제 또는 다중 테넌트 시스템에 사용되며 스코프 인터페이스를 모델에 구현하고 등록해야합니다. 3. 스코프에는 연도 또는 월별 필터링 기사와 같은 매개 변수가 장착 될 수 있으며 호출 할 때 해당 매개 변수가 전달됩니다. 4. 코드 선명도 및 재사용 성을 개선하는 데 사용할 때 명명 사양, 체인 호출, 임시 비활성화 및 조합 확장에주의하십시오.

CreateAhelpers.phpfileInapp/helperswithCustOmFunctionsikeFormatPrice, isactiveroute, andisAdmin.2.addTheFileTothe "파일"sectionOfcomposer.jsonUnderAutoLoad.3.runcomposerDump-AUTOLOADTOMAKETHINGTICTIONSGLOBELYAVAILABLE.4.USETHEHELPERFUNCUNTION

USEMOCKERYFORCUSTOMDENCENTICESBYSETEXPINTIONSWITHSHOULDRECEIVE ()

추천, 추천, 추천 코드 및 사용 시간을 포함하여 추천 관계를 기록 할 추천 테이블을 작성합니다. 2. 추천 데이터를 관리하기 위해 사용자 모델의 SONGSTOMONY 및 HASMANY 관계 정의; 3. 등록 할 때 고유 한 권장 코드를 생성합니다 (모델 이벤트를 통해 구현할 수 있음). 4. 등록 중 매개 변수를 쿼리하여 권장 코드를 캡처하고 확인 후 권장 관계를 설정하고 자체 권장을 방지합니다. 5. 권장 사용자가 지정된 동작 (구독 순서)을 완료하면 보상 메커니즘을 트리거합니다. 6. 공유 가능한 추천 링크를 생성하고 Laravel Signature URL을 사용하여 보안을 향상시킵니다. 7. 총 권장 사항 수 및 변환 숫자와 같은 대시 보드에 권장 통계를 표시합니다. 데이터베이스 제약, 세션 또는 쿠키가 지속되도록해야합니다.

Checkphp> = 8.1, Composer, andwebserver; 2. CloneorcreateProjectandruncomposerInstall; 3.copy.env.exampleto.envandrunphpartisankey : 생성; 4. 4. SetDatabasecredentitySin.envandRunphPartisanMigrate-Seed; 5.StartServerWithPhPartisAnserve; 6.OptionalLyRunnpmins

시드기 파일 생성 : Phpartisanmake : SeederUserseeder를 사용하여 시드기 클래스를 생성하고 실행 메소드에서 모델 팩토리 또는 데이터베이스 쿼리를 통해 데이터를 삽입하십시오. 2. DatabaseSeeder의 다른 시드러에게 전화하십시오 : REGISTERESEEDER, POSTSEEDER 등 $ this-> Call ()을 통해 종속성이 올바른지 확인하십시오. 3. 시드러 실행 : phpartisandb를 실행하십시오 : 씨앗을 모두 등록 된 시드기를 실행하거나 phpartisangymigrate를 사용하십시오 : 신선한-데이터를 재설정하고 리필하십시오. 4

새로운 Laravel 프로젝트를 만들고 서비스를 시작하십시오. 2. 모델, 마이그레이션 및 컨트롤러를 생성하고 마이그레이션을 실행하십시오. 3. Routes/API.php에서 RESTFUL 경로를 정의합니다. 4. PostController에서 추가, 삭제, 수정 및 쿼리 메소드를 구현하고 JSON 응답을 반환합니다. 5. Postman 또는 Curl을 사용하여 API 기능을 테스트하십시오. 6. 선택적으로 성소를 통해 API 인증을 추가합니다. 마지막으로 실제 적용에 적합한 명확한 구조, 완전하고 확장 가능한 Laravelrestapi를 얻습니다.
