EXCEPT 절은 두 번째 쿼리의 결과를 제외하고 첫 번째 쿼리의 결과에만 포함된 행을 반환합니다.
- 두 쿼리는 컬럼 수, 컬럼 순서, 데이터 타입이 서로 같아야 합니다.
EXCEPT의 결과에는 중복 행이 포함될 수 있습니다. 이를 원하지 않으면EXCEPT DISTINCT를 사용하십시오.- 괄호를 지정하지 않으면 여러
EXCEPTSQL 문은 왼쪽에서 오른쪽 순서로 실행됩니다. EXCEPT연산자는UNION절과 동일한 우선순위를 가지며,INTERSECT절보다 우선순위가 낮습니다.
구문
EXCEPT()를 사용할 수 있습니다:
예시
EXCEPT 절 사용 방법을 보여줍니다.
EXCEPT 절을 사용한 숫자 필터링
Query
Response
EXCEPT()를 사용해 특정 컬럼 제외하기
EXCEPT()는 결과에서 특정 컬럼을 빠르게 제외할 때 사용할 수 있습니다. 예를 들어, 아래 예시처럼 몇 개의 특정 컬럼만 제외하고 테이블의 모든 컬럼을 선택할 수 있습니다:
Query
Response
암호화폐 데이터에 EXCEPT와 INTERSECT 사용하기
EXCEPT와 INTERSECT는 Boolean 논리만 다를 뿐 비슷한 방식으로 사용할 수 있는 경우가 많으며, 공통 컬럼(또는 여러 컬럼)을 가진 두 테이블이 있을 때 모두 유용합니다.
예를 들어, 거래 가격과 거래량이 포함된 과거 암호화폐 데이터 수백만 행이 있다고 가정해 보겠습니다:
Query
Response
holdings라는 테이블(table)이 있다고 가정해 보겠습니다:
Query
EXCEPT를 사용하면 **“보유한 코인 중 한 번도 $10 아래로 거래된 적이 없는 코인은 무엇입니까?”**와 같은 질문에 답할 수 있습니다:
Query
Response
EXCEPT DISTINCT 사용하기
EXCEPT에 DISTINCT를 추가할 수 있습니다:
Query
Response