>데이터 베이스 >MySQL 튜토리얼 >교리 2를 사용하여 WHERE ... IN 하위 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

교리 2를 사용하여 WHERE ... IN 하위 쿼리를 효율적으로 수행하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-13 21:36:45609검색

How to Efficiently Perform a WHERE ... IN Subquery with Doctrine 2?

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

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