>  기사  >  데이터 베이스  >  Doctrine 2 DBAL을 사용하여 하위 쿼리를 결합하는 방법은 무엇입니까?

Doctrine 2 DBAL을 사용하여 하위 쿼리를 결합하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-10-23 23:50:29669검색

How to Join Subqueries with Doctrine 2 DBAL?

Doctrine 2 DBAL을 사용하여 하위 쿼리 결합

소개

Zend Framework 애플리케이션을 Doctrine 2.5 DBAL로 마이그레이션할 때 하위 쿼리에 결합하는 데 문제가 발생할 수 있습니다. 이 문서의 목적은 이 특정 문제에 대한 포괄적인 가이드를 제공하는 것입니다.

문제

주어진 Zend_Db 쿼리에는 특정 사용자 설문조사에 대한 최소 타임스탬프를 검색하는 하위 쿼리가 있습니다. 이후 기본 쿼리는 이 하위 쿼리를 조인하여 추가 데이터를 가져옵니다. 목표는 Doctrine 2.5의 쿼리 빌더를 사용하여 이 기능을 복제하는 것입니다.

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

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