>데이터 베이스 >MySQL 튜토리얼 >내 T-SQL LEFT JOIN이 3개가 아닌 2개의 행만 반환하는 이유는 무엇입니까?

내 T-SQL LEFT JOIN이 3개가 아닌 2개의 행만 반환하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-06 00:55:39958검색

Why is my T-SQL LEFT JOIN only returning two rows instead of three?

Left Join이 예상 결과를 산출하지 않음

제공된 T-SQL 코드는 #appSteps 및 #appProgress라는 두 테이블 간의 Left 조인을 수행하는 것을 목표로 하지만 결과 집합은 예상되는 행 대신 두 개의 행만 포함되어 있습니다. three.

문제

이 문제는 오른쪽 테이블(#appProgress)이 WHERE 절에 포함되어 있기 때문에 발생합니다:

where s.section is not null
and p.appId = 101

설명

A왼쪽 JOIN은 오른쪽 테이블에 일치하는 레코드가 없는 행을 포함하여 왼쪽 테이블의 모든 행을 반환하기 위한 것입니다. 그러나 WHERE 절에 오른쪽 테이블을 포함하면 쿼리가 INNER JOIN처럼 효과적으로 작동하여 오른쪽 테이블의 레코드와 일치하지 않고 왼쪽 테이블의 행을 필터링합니다.

해결책

원하는 결과 집합을 얻으려면 오른쪽 테이블의 필터 조건을 LEFT의 ON 절로 이동하세요. JOIN:

Select P.appId, S.stepId, S.section, P.start
From #appSteps S With (NoLock)
Left Join #appProgress P On S.stepId = P.stepId 
                           And P.appId = 101
Where S.section Is Not Null

ON 절에 조건을 배치하면 두 테이블의 일치하는 행이 먼저 조인된 다음 WHERE 절이 적용되어 결과를 추가로 필터링하여 null이 아닌 행만 허용됩니다. 섹션의 값이 반환됩니다.

위 내용은 내 T-SQL LEFT JOIN이 3개가 아닌 2개의 행만 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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