여러 품목 조인에서 중복 주문 번호 방지
주문당 여러 줄 항목이 있는 테이블과 관련된 데이터베이스 조인으로 인해 결과에 주문 번호가 중복되는 경우가 많습니다. 이 기사에서는 고유한 주문당 하나의 기록만 검색하는 효율적인 솔루션을 살펴봅니다.
초기 접근방식과 단점
간단한 접근 방식은 '상위 1' 광고 항목만 선택하는 것입니다. 그러나 내부 Select 문 내에서 외부 테이블에 직접 액세스하는 데 한계가 있어 실패합니다.
효율적인 솔루션: CROSS APPLY
CROSS APPLY
연산자는 다음과 같은 우아한 솔루션을 제공합니다.
<code class="language-sql">SELECT Orders.OrderNumber, LineItems2.Quantity, LineItems2.Description FROM Orders CROSS APPLY ( SELECT TOP 1 LineItems.Quantity, LineItems.Description FROM LineItems WHERE LineItems.OrderID = Orders.OrderID ) LineItems2</code>
CROSS APPLY
각 주문의 첫 번째 품목을 효율적으로 검색하여 주문 번호 중복을 방지합니다.
이전 SQL Server 버전의 대안: INNER JOIN
2005년 이전 SQL Server 버전의 경우 INNER JOIN
는 다음과 같은 유사한 솔루션을 제공합니다.
<code class="language-sql">SELECT Orders.OrderNumber, LineItems.Quantity, LineItems.Description FROM Orders JOIN LineItems ON LineItems.LineItemGUID = ( SELECT TOP 1 LineItemGUID FROM LineItems WHERE OrderID = Orders.OrderID )</code>
결정적인 결과 보장
결정적으로 TOP 1
절이 없는 ORDER BY
는 비결정적입니다. 선택한 광고 항목은 데이터가 변경되지 않은 경우에도 쿼리 실행마다 달라질 수 있습니다. 일관된 결과를 보장하려면 항상 내부 쿼리 내에 ORDER BY
절을 포함하세요.
위 내용은 여러 품목이 포함된 테이블을 조인할 때 중복된 주문 번호를 제거하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!