집 >데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블을 조인할 때 각 주문의 첫 번째 항목만 효율적으로 선택하는 방법은 무엇입니까?
데이터베이스 테이블 조인: 주문당 첫 번째 줄 항목만 선택
데이터베이스 작업에서 하나의 주문에 여러 관련 항목이 포함될 수 있는 Orders
및 LineItems
와 같은 테이블을 조인할 때 일반적인 문제가 발생합니다. 이로 인해 조인된 결과 집합에 중복 데이터가 발생하는 경우가 많습니다. 목표는 주문당 하나의 광고 항목만 효율적으로 검색하는 것입니다.
순진한 접근 방식에는 TOP 1
을 사용하는 것이 포함될 수 있지만 하위 쿼리 내에서 적절한 테이블 참조가 없으면 오류가 발생할 수 있습니다.
효과적인 솔루션: CROSS APPLY
JOIN
ORDER BY
을 사용한 및
두 가지 강력한 방법으로 이 문제를 효과적으로 해결할 수 있습니다.
방법 1: CROSS APPLY
이 접근 방식은 CROSS APPLY
을 사용하여 각 주문의 최상위 라인 항목을 선택하는 하위 쿼리로 Orders
테이블을 조인합니다.
<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>
방법 2: JOIN
ORDER BY
과 함께
이 방법은 조인 조건이 품목을 주문하는 하위 쿼리에서 JOIN
를 선택하고 각 주문에 대해 최상위 항목을 선택하는 LineItemGUID
절을 사용합니다.
<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 ORDER BY LineItemGUID );</code>
두 가지 방법 모두 각 주문에 대해 단일 품목만 반환되도록 합니다. 결정적으로 결정적인 결과를 얻으려면 하위 쿼리 내에 ORDER BY
절을 포함하는 것이 필수적입니다. ORDER BY
와 함께 TOP 1
를 생략하면 "첫 번째" 줄 항목이 쿼리 실행에 따라 달라질 수 있으므로 예측할 수 없는 결과가 발생합니다. ORDER BY
을 사용하면 선택한 주문 기준에 따라 특정 광고 항목을 일관되게 선택할 수 있습니다.
위 내용은 데이터베이스 테이블을 조인할 때 각 주문의 첫 번째 항목만 효율적으로 선택하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!