교리 2의 WHERE ... IN
하위 쿼리 최적화
특정 품목이 포함된 주문과 연관된 주문 품목을 검색하는 것은 Doctrine 2 프레임워크 내에서 어려운 일입니다. 간단한 SQL 솔루션은 다음과 같습니다.
<code class="language-sql">SELECT DISTINCT i.id, i.name, order.name FROM items i JOIN orders o ON i.order_id=o.id WHERE o.id IN ( SELECT o2.id FROM orders o2 JOIN items i2 ON i2.order_id=o2.id AND i2.id=5 ) AND i.id != 5 ORDER BY o.orderdate DESC LIMIT 10</code>
이 SQL 쿼리는 원하는 결과를 효율적으로 달성합니다. 그러나 이를 Doctrine 2의 쿼리 빌더에서 직접 복제하려면 보다 미묘한 접근 방식이 필요합니다.
<code class="language-php">$expr = $em->getExpressionBuilder(); $em->createQueryBuilder() ->select(array('DISTINCT i.id', 'i.name', 'o.name')) ->from('Item', 'i') ->join('i.order', 'o') ->where( $expr->in( 'o.id', $em->createQueryBuilder() ->select('o2.id') ->from('Order', 'o2') ->join('Item', 'i2', \Doctrine\ORM\Query\Expr\Join::WITH, $expr->andX( $expr->eq('i2.order', 'o2'), $expr->eq('i2.id', '?1') )) ->getDQL() ) ) ->andWhere($expr->neq('i.id', '?2')) ->orderBy('o.orderdate', 'DESC') ->setParameter(1, 5) ->setParameter(2, 5);</code>
이 Doctrine 2 코드는 기능적으로 동등한 것을 제공합니다. 모델별 조정이 필요할 수 있습니다. 잠재적인 개선이 필요한 영역에는 하위 쿼리를 사용하여 IN
절의 성능 최적화, 효율성 향상을 위한 대안 탐색, 더 나은 가독성을 위해 잠재적으로 두 매개 변수를 하나로 통합하는 것이 포함됩니다. 이 예는 강력하고 효율적인 솔루션을 만들기 위한 기반이 됩니다.
위 내용은 교리 2를 사용하여 WHERE ... IN 하위 쿼리를 효율적으로 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!