> 데이터 베이스 > MySQL 튜토리얼 > SQL JOIN의 WHERE와 ON: 언제 각 절을 사용해야 합니까?

SQL JOIN의 WHERE와 ON: 언제 각 절을 사용해야 합니까?

DDD
풀어 주다: 2025-01-05 13:10:44
원래의
272명이 탐색했습니다.

WHERE vs. ON in SQL JOINs: When Should I Use Each Clause?

JOIN에서 WHERE 절과 ON 조건의 차이점 탐색

SQL 실무자는 JOIN 작업을 수행할 때 WHERE 절과 ON 조건을 같은 의미로 사용하는 경우가 많습니다. . 두 접근 방식 모두 동일한 결과를 반환할 수 있지만 고려해야 할 미묘한 차이가 있습니다.

제공된 예에서는 두 개의 SQL 쿼리가 제공됩니다.

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON b.BarId = f.BarId
WHERE b.IsApproved = 1;
로그인 후 복사

SELECT *
FROM Foo AS f
INNER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);
로그인 후 복사

두 쿼리 모두 동일한 행 집합을 반환하지만 실행에는 결정적인 차이가 있습니다. 필터가 WHERE 절에 배치되면 JOIN 연산 후에 적용됩니다. 즉, JOIN은 b.IsApproved가 false인 경우에도 두 테이블 모두에서 일치하는 모든 행을 검색합니다. 그런 다음 WHERE 절은 b.IsApproved = 1 기준을 충족하지 않는 행을 필터링합니다.

반대로 필터가 ON 조건에 있는 경우 JOIN 전에 조건이 평가됩니다. 결과적으로 b.BarId 및 b.IsApproved가 모두 지정된 기준을 충족하는 행만 JOIN에 포함됩니다.

외부 조인 및 필터 배치

그러나 , 이 차이는 외부 조인을 처리할 때 특히 중요합니다. 다음 왼쪽 외부 조인 쿼리를 고려하세요.

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.IsApproved = 1) AND (b.BarId = f.BarId);
로그인 후 복사

이 경우 ON 조건의 필터는 b.IsApproved가 false인 행이나 지정된 f에 대해 일치하는 b.BarId가 없는 행을 제외합니다. .BarId. 이 동작은 WHERE 절에 필터를 배치하는 것과 다릅니다.

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved = 1;
로그인 후 복사

두 번째 쿼리에서 b.IsApproved가 false이거나 실패한 조인과 관련된 행은 계속 반환되지만 b.IsApproved는 NULL로 설정하세요.

따라서 외부 조인을 사용할 때는 필터 배치를 신중하게 고려하는 것이 중요합니다. ON 조건은 조인 앞의 행을 필터링하고 WHERE 절은 조인 뒤의 결과를 필터링합니다.

토의를 완료하려면 왼쪽 외부 조인에서 OPTIONAL 필터를 원하는 경우 다음 쿼리는 올바른 배치를 보여줍니다. :

SELECT *
FROM Foo AS f
LEFT OUTER JOIN Bar AS b ON (b.BarId = f.BarId)
WHERE b.IsApproved IS NULL OR b.IsApproved = 1;
로그인 후 복사

이 쿼리는 조인이 성공하고 b.IsApproved가 기준을 충족하는 행과 조인이 실패한 행을 반환합니다(결과적으로 b.IsApproved의 경우 NULL 값).

위 내용은 SQL JOIN의 WHERE와 ON: 언제 각 절을 사용해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿