>데이터 베이스 >MySQL 튜토리얼 >데이터베이스 테이블을 조인할 때 각 주문의 첫 번째 항목만 효율적으로 선택하는 방법은 무엇입니까?

데이터베이스 테이블을 조인할 때 각 주문의 첫 번째 항목만 효율적으로 선택하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-17 06:13:09170검색

How to Efficiently Select Only the First Line Item for Each Order When Joining Database Tables?

데이터베이스 테이블 조인: 주문당 첫 번째 줄 항목만 선택

데이터베이스 작업에서 하나의 주문에 여러 관련 항목이 포함될 수 있는 OrdersLineItems와 같은 테이블을 조인할 때 일반적인 문제가 발생합니다. 이로 인해 조인된 결과 집합에 중복 데이터가 발생하는 경우가 많습니다. 목표는 주문당 하나의 광고 항목만 효율적으로 검색하는 것입니다.

순진한 접근 방식에는 TOP 1을 사용하는 것이 포함될 수 있지만 하위 쿼리 내에서 적절한 테이블 참조가 없으면 오류가 발생할 수 있습니다.

효과적인 솔루션: CROSS APPLYJOINORDER 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: JOINORDER 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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