>데이터 베이스 >MySQL 튜토리얼 >Left 조인 및 WHERE 절: 어떻게 상호 작용하며 예상치 못한 결과를 방지하려면 어떻게 해야 합니까?

Left 조인 및 WHERE 절: 어떻게 상호 작용하며 예상치 못한 결과를 방지하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-12-31 18:05:121028검색

Left Joins and WHERE Clauses: How Do They Interact, and How Can I Avoid Unexpected Results?

왼쪽 조인과 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 값이 있는 모든 행을 제거합니다.

위 예에서 왼쪽 조인의 의도된 동작을 유지하려면 다음 중 하나를 사용할 수 있습니다. 접근 방식:

  • WHERE 절을 다시 작성합니다. c.foobar = 'somethingelse'를 다음 조건으로 바꿉니다. AND(c.foobar = 'somethingelse' OR c.foobar IS NULL)와 같은 NULL 값을 허용합니다.
  • 필터를 Join 조건자로 이동합니다. LEFT JOIN 절을 다음과 같이 수정합니다. 다음과 같습니다: LEFT JOIN tableThree AS c ON b.pk = c.fk AND c.foobar = 'somethingelse'. 조인 자체 내에 필터를 배치하면 c.foobar의 NULL 값이 계속 유지되므로 왼쪽 조인의 동작은 변경되지 않습니다.

위 내용은 Left 조인 및 WHERE 절: 어떻게 상호 작용하며 예상치 못한 결과를 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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