집합 연산자
적용 대상: Databricks SQL Databricks Runtime
두 하위 쿼리를 단일 쿼리로 결합합니다. Databricks SQL에서는 세 가지 유형의 집합 연산자를 지원합니다.
EXCEPT
INTERSECT
UNION
구문
subquery1 { { UNION [ ALL | DISTINCT ] |
INTERSECT [ ALL | DISTINCT ] |
EXCEPT [ ALL | DISTINCT ] } subquery2 } [...] }
subquery1, subquery2
subquery
에 지정된 두 절입니다. 두 하위 쿼리는 열 수가 같고 해당하는 각 열에 대해 최소 공용 형식을 공유해야 합니다.UNION [ALL | DISTINCT]
subquery1 plus the rows of
subquery2`의 결과를 반환합니다.ALL
을 지정하면 중복 행이 유지됩니다.DISTINCT
를 지정하면 결과에 중복 행이 포함되지 않습니다. 기본값입니다.INTERSECT [ALL | DISTINCT]
두 하위 쿼리 모두에 있는 행 집합을 반환합니다.
ALL
을 지정하면subquery1
및subquery
에서 여러 번 나타나는 행이 여러 번 반환됩니다.DISTINCT
를 지정하면 결과에 중복 행이 포함되지 않습니다. 기본값입니다.EXCEPT [ALL | DISTINCT ]
subquery1
에는 있지만subquery2
에는 없는 행을 반환합니다.ALL
을 지정하면subquery2
의 각 행에 대해subquery1
에 있을 수 있는 일치하는 여러 행 중 하나만 제거됩니다.DISTINCT
를 지정하면 연산을 적용하기 전에subquery1
에서 중복 행이 제거되므로 일치하는 모든 행이 제거되고 결과에는 중복 행(일치하거나 일치하지 않는 행)이 남지 않습니다. 기본값입니다.MINUS
의 대체 구문으로EXCEPT
를 지정할 수 있습니다.
집합 연산자를 연결하면 INTERSECT
가 UNION
및 EXCEPT
보다 우선 순위가 높습니다.
각 결과 열의 형식은 subquery1
및 subquery2
에서 해당 열의 최소 공용 형식입니다.
결과 열이 STRING
인 경우, 하위 쿼리의 열에 대해 데이터 정렬 우선 규칙를 적용하여 데이터 정렬 방식이 결정됩니다.
예제
-- Use number1 and number2 tables to demonstrate set operators in this page.
> CREATE TEMPORARY VIEW number1(c) AS VALUES (3), (1), (2), (2), (3), (4);
> CREATE TEMPORARY VIEW number2(c) AS VALUES (5), (1), (1), (2);
> SELECT c FROM number1 EXCEPT SELECT c FROM number2;
3
4
> SELECT c FROM number1 MINUS SELECT c FROM number2;
3
4
> SELECT c FROM number1 EXCEPT ALL (SELECT c FROM number2);
3
3
4
> SELECT c FROM number1 MINUS ALL (SELECT c FROM number2);
3
3
4
> (SELECT c FROM number1) INTERSECT (SELECT c FROM number2);
1
2
> (SELECT c FROM number1) INTERSECT DISTINCT (SELECT c FROM number2);
1
2
> (SELECT c FROM number1) INTERSECT ALL (SELECT c FROM number2);
1
2
2
> (SELECT c FROM number1) UNION (SELECT c FROM number2);
1
3
5
4
2
> (SELECT c FROM number1) UNION DISTINCT (SELECT c FROM number2);
1
3
5
4
2
> SELECT c FROM number1 UNION ALL (SELECT c FROM number2);
3
1
2
2
3
4
5
1
1
2