>데이터 베이스 >MySQL 튜토리얼 >날짜가 겹치는 두 개의 SQL 테이블을 병합하고 결과에서 고유한 날짜 값을 보장하려면 어떻게 해야 합니까?

날짜가 겹치는 두 개의 SQL 테이블을 병합하고 결과에서 고유한 날짜 값을 보장하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-12-27 20:26:18147검색

How Can I Merge Two SQL Tables with Overlapping Dates and Ensure Unique Date Values in the Result?

SQL에서 고유한 날짜 값을 가진 두 테이블 병합

데이터 통합 ​​시나리오에서 구조는 비슷하지만 데이터가 겹칠 가능성이 있는 테이블을 병합하면 문제가 발생할 수 있습니다. 특히 중복 값을 처리할 때 문제가 됩니다. 다음 두 테이블을 고려하십시오.

CREATE TABLE Inbound (
    Inbound_Date DATE,
    Product TEXT,
    InboundType TEXT,
    Quantity VARCHAR(255)
);

CREATE TABLE Outbound (
    Outbound_Date DATE,
    Product TEXT,
    OutboundType TEXT
);

기존 UNION 쿼리를 사용하면 이러한 테이블을 다음과 같이 병합할 수 있습니다.

SELECT 
   Inbound_Date As Date, 
   Product, 
   SUM(Quantity) as Inbound, 0 as Outbound
 FROM Inbound
 GROUP BY 1,2
) 

UNION ALL

(SELECT
   Outbound_Date,
   Product,
   0 as Inbound, COUNT("Outbound_Type")  as Outbound 
 FROM Outbound
 GROUP BY 1,2
)

ORDER BY 1,2;

그러나 이 접근 방식을 사용하면 중복 날짜가 존재할 수 있습니다. 각 날짜가 고유한지 확인하기 위해 UNION ALL 및 GROUP BY를 사용하도록 쿼리를 수정할 수 있습니다.

SELECT Date, Product, SUM(Inbound) as Inbound, SUM(Outbound) as Outbound
FROM ((SELECT Inbound_Date As Date, Product, SUM(Quantity) as Inbound, 0 as Outbound
      FROM Inbound
      GROUP BY 1,2
     ) UNION ALL
     (SELECT Outbound_Date, Product, 0 as Inbound, COUNT(*)  as Outbound 
      FROM Outbound
      GROUP BY 1,2
     )
    ) io
GROUP BY Date, Product;

이 쿼리는 먼저 UNION ALL 작업을 수행하여 두 테이블의 행을 결합하여 단일 세트를 생성합니다. 날짜와 제품이 겹치는 행 그런 다음 중첩된 쿼리 블록을 사용하여 각 날짜 및 제품 조합에 대한 인바운드 및 아웃바운드 수량 합계를 계산합니다. 마지막으로 GROUP BY 절을 적용하여 중복된 날짜 값을 제거하여 각 날짜가 최종 결과에 한 번만 표시되도록 합니다.

결과적으로 수정된 쿼리는 고유한 날짜가 포함된 테이블을 생성하므로 유용할 수 있습니다. 추가 분석 또는 데이터 조작 작업을 위해.

위 내용은 날짜가 겹치는 두 개의 SQL 테이블을 병합하고 결과에서 고유한 날짜 값을 보장하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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