제공된 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!