목차
교리에서 Left Join을 수행하는 방법
발생한 문제
왼쪽 조인 구현
백엔드 개발 PHP 튜토리얼 Doctrine에서 왼쪽 조인 중에 \'Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got \'ON\'\' 오류를 해결하는 방법은 무엇입니까?

Doctrine에서 왼쪽 조인 중에 \'Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got \'ON\'\' 오류를 해결하는 방법은 무엇입니까?

Oct 29, 2024 am 04:24 AM

How to Resolve the

교리에서 Left Join을 수행하는 방법

복잡한 데이터 모델로 작업할 때 여러 테이블 간의 관계를 설정하여 여러 테이블에서 데이터를 검색해야 합니다. Left 조인을 사용하면 한 테이블에서 모든 행을 가져오고 다른 테이블에서는 일치하는 행만 가져올 수 있습니다.

발생한 문제

Doctrine에서 Left 조인을 시도할 때 발생할 수 있는 일반적인 오류는 수신입니다. 다음 구문 오류:

[Syntax Error] line 0, col 98: Error: Expected DoctrineORMQueryLexer::T_WITH, got 'ON'

이 오류는 "ON"이 사용된 경우 발생합니다. "WITH" 대신 조인 절을 사용하세요. 이 문제를 해결하려면 아래와 같이 "ON"을 "WITH"로 바꾸십시오.

<code class="php">$qb-&gt;leftJoin('User\Entity\User', 'u', \Doctrine\ORM\Query\Expr\Join::WITH, 'a.user = u.id')</code>
로그인 후 복사

왼쪽 조인 구현

Doctrine에서 왼쪽 조인을 수행하려면 두 가지 접근 방식이 있습니다.

연결 포함:

엔티티가 조인하려는 테이블과 연결되어 있는 경우 다음 구문을 사용할 수 있습니다.

<code class="php">$qb
    -&gt;select('a', 'u')
    -&gt;from('Credit\Entity\UserCreditHistory', 'a')
    -&gt;leftJoin('a.user', 'u')
    -&gt;where('u = :user')
    -&gt;setParameter('user', $users)
    -&gt;orderBy('a.created_at', 'DESC');</code>
로그인 후 복사

In 이 경우 "CreditEntityUserCreditHistory#user"는 두 엔터티 간의 연결을 나타냅니다.

연결 없음:

연결이 없으면 다음 구문을 사용할 수 있습니다.

<code class="php">$qb
    -&gt;select('a', 'u')
    -&gt;from('Credit\Entity\UserCreditHistory', 'a')
    -&gt;leftJoin(
        'User\Entity\User',
        'u',
        \Doctrine\ORM\Query\Expr\Join::WITH,
        'a.user = u.id'
    )
    -&gt;where('u = :user')
    -&gt;setParameter('user', $users)
    -&gt;orderBy('a.created_at', 'DESC');</code>
로그인 후 복사

이 쿼리는 두 테이블 모두에서 레코드를 검색하고 다음 형식의 배열이 포함된 결과 집합을 반환합니다.

<code class="php">array(
    array(
        0 =&gt; UserCreditHistory instance,
        1 =&gt; Userinstance,
    ),
    array(
        0 =&gt; UserCreditHistory instance,
        1 =&gt; Userinstance,
    ),
    // ...
)</code>
로그인 후 복사

위 내용은 Doctrine에서 왼쪽 조인 중에 \'Expected Doctrine\\ORM\\Query\\Lexer::T_WITH, got \'ON\'\' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

뜨거운 기사 태그

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

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

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) 11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄) Mar 03, 2025 am 10:49 AM

11 최고의 PHP URL 쇼트너 스크립트 (무료 및 프리미엄)

Instagram API 소개 Instagram API 소개 Mar 02, 2025 am 09:32 AM

Instagram API 소개

Laravel의 플래시 세션 데이터로 작업합니다 Laravel의 플래시 세션 데이터로 작업합니다 Mar 12, 2025 pm 05:08 PM

Laravel의 플래시 세션 데이터로 작업합니다

Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Laravel 테스트에서 단순화 된 HTTP 응답 조롱 Mar 12, 2025 pm 05:09 PM

Laravel 테스트에서 단순화 된 HTTP 응답 조롱

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법 Mar 14, 2025 am 11:42 AM

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법

Laravel Back End : Part 2, React가있는 React 앱 구축 Laravel Back End : Part 2, React가있는 React 앱 구축 Mar 04, 2025 am 09:33 AM

Laravel Back End : Part 2, React가있는 React 앱 구축

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트 Mar 13, 2025 pm 12:08 PM

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트

라 라벨에서 알림 라 라벨에서 알림 Mar 04, 2025 am 09:22 AM

라 라벨에서 알림

See all articles