왼쪽 조인과 WHERE 절의 특이한 점
데이터 검색 작업을 수행할 때 개발자는 종종 왼쪽 조인을 사용하여 여러 테이블의 정보를 결합합니다. 그러나 왼쪽 조인과 함께 WHERE 절을 사용하면 잠재적으로 왼쪽 조인의 동작이 변형될 수 있는 일반적인 함정이 발생합니다.
다음 SQL 문을 고려해 보세요.
SELECT a.foo b.bar c.foobar FROM tableOne AS a INNER JOIN tableTwo AS b ON a.pk = b.fk LEFT JOIN tableThree AS c ON b.pk = c.fk WHERE a.foo = 'something' AND c.foobar = 'somethingelse'
직관적으로 다음과 같습니다. 이 명령문은 c.foobar에 대한 필터 조건을 지정하여 tableThree와 tableTwo 사이에 왼쪽 조인을 수행할 것으로 예상됩니다. 그러나 c.foobar = 'somethingelse'를 포함하는 WHERE 절이 있으면 실수로 왼쪽 조인의 특성이 변경됩니다.
왼쪽 조인의 오른쪽 값(이 경우 c.foobar)이 다음과 같은 경우 WHERE 절에 포함되면 값이 NULL이 아닌 행만 결과 집합에 포함됩니다. 따라서 왼쪽 조인은 효과적으로 내부 조인처럼 작동하여 c.foobar에 대해 NULL 값이 있는 모든 행을 제거합니다.
위 예에서 왼쪽 조인의 의도된 동작을 유지하려면 다음 중 하나를 사용할 수 있습니다. 접근 방식:
위 내용은 Left 조인 및 WHERE 절: 어떻게 상호 작용하며 예상치 못한 결과를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!