>데이터 베이스 >MySQL 튜토리얼 >SQL의 UNION 연산자를 사용하여 여러 테이블의 데이터를 어떻게 결합할 수 있습니까?

SQL의 UNION 연산자를 사용하여 여러 테이블의 데이터를 어떻게 결합할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-29 09:43:15638검색

How Can I Combine Data from Multiple Tables Using SQL's UNION Operator?

통합 출력을 위한 테이블 결합

여러 데이터 테이블로 작업할 때 이를 결합하여 응집력 있는 단일 출력을 생성하는 것은 일반적일 수 있습니다. 일. 이를 달성하려면 데이터 구조와 쿼리 작업을 이해하는 것이 중요합니다.

KnownHours와 UnknownHours라는 두 개의 테이블이 있다고 상상해 보세요. 목표는 월 열을 무시하고 이러한 테이블을 병합하여 다양한 청구 번호 및 카테고리 ID와 관련된 시간에 대한 포괄적인 보기를 얻는 것입니다.

이를 달성하기 위해 UNION 연산자는 강력한 도구 역할을 합니다. 이를 통해 여러 쿼리의 결과를 결합하여 본질적으로 함께 추가할 수 있습니다. SQL에서 UNION의 구문은 다음과 같습니다.

SELECT ...
FROM table1
UNION
SELECT ...
FROM table2

이 경우 각 ChargeNum/Category 조합에 대해 시간을 그룹화해야 합니다. UNION 쿼리를 아래와 같이 수정할 수 있습니다.

SELECT ChargeNum, CategoryID, SUM(Hours)
FROM KnownHours
GROUP BY ChargeNum, CategoryID
UNION ALL
SELECT ChargeNum, 'Unknown' AS CategoryID, SUM(Hours)
FROM UnknownHours
GROUP BY ChargeNum

UNION ALL 키워드는 중복 행을 제거하려고 시도하지 않는다는 점에서 UNION과 약간 다릅니다. 이렇게 하면 두 쿼리의 모든 행이 최종 결과에 포함됩니다.

UNION ALL 연산을 활용하면 KnownHours와 UnknownHours의 결과를 효과적으로 결합하여 원하는 출력이 포함된 포괄적인 테이블을 생성할 수 있습니다.

ChargeNum    CategoryID     Hours
111111       1              90
111111       2              50
111111       Unknown        110.5
222222       1              40
222222       Unknown        25.5

UNION 연산자를 이해하면 여러 소스의 데이터를 병합하여 데이터 분석을 위한 맞춤화되고 포괄적인 출력을 구성할 수 있는 강력한 수단을 제공할 수 있습니다. 필요합니다.

위 내용은 SQL의 UNION 연산자를 사용하여 여러 테이블의 데이터를 어떻게 결합할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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