Zend Framework 애플리케이션을 Doctrine 2.5 DBAL로 마이그레이션할 때 하위 쿼리에 결합하는 데 문제가 발생할 수 있습니다. 이 문서의 목적은 이 특정 문제에 대한 포괄적인 가이드를 제공하는 것입니다.
주어진 Zend_Db 쿼리에는 특정 사용자 설문조사에 대한 최소 타임스탬프를 검색하는 하위 쿼리가 있습니다. 이후 기본 쿼리는 이 하위 쿼리를 조인하여 추가 데이터를 가져옵니다. 목표는 Doctrine 2.5의 쿼리 빌더를 사용하여 이 기능을 복제하는 것입니다.
처음에는 Doctrine이 하위 쿼리 조인을 지원하지 않는 것으로 여겨졌습니다. 그러나 해결 방법이 있습니다.
해결책은 하위 쿼리의 원시 SQL을 가져와서 대괄호로 묶는 것입니다. 조인 구문은 일반 조인 작업과 유사합니다. 그러나 하위 쿼리에 사용되는 매개 변수는 기본 쿼리에서 정의되어야 합니다.
<code class="php">$subSelect = $connection->createQueryBuilder() ->select(array('userSurveyID', 'MIN(timestamp) timestamp')) ->from('user_survey_status_entries') ->where('status = :status') ->groupBy('userSurveyID'); $select = $connection->createQueryBuilder() ->select($selectColNames) ->from('user_surveys', 'us') ->leftJoin('us', sprintf('(%s)', $subSelect->getSQL()), 'firstAccess', 'us.userSurveyID = firstAccess.userSurveyID') ->setParameter('status', UserSurveyStatus::ACCESSED) ->where('us.surveyID = :surveyID') ->setParameter('surveyID', $surveyID);</code>
이 해결 방법을 사용하면 Doctrine 2.5 DBAL에서 하위 쿼리를 조인할 수 있습니다. . 하위 쿼리의 원시 SQL을 얻고 해당 매개변수를 기본 쿼리에 설정하면 원하는 쿼리 구조를 얻을 수 있습니다.
위 내용은 Doctrine 2 DBAL을 사용하여 하위 쿼리를 결합하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!