LINQ to SQL: 여러 조인 조건을 사용하여 왼쪽 외부 조인 향상
LINQ to SQL에서 왼쪽 외부 조인은 결합을 위한 강력한 메커니즘을 제공합니다. 여러 테이블의 데이터. 그러나 추가 조인 조건이 포함된 시나리오를 처리할 때는 표준 접근 방식을 확장하는 기술을 탐색해야 합니다.
SQL 쿼리를 고려하세요.
SELECT f.value FROM period as p LEFT OUTER JOIN facts AS f ON p.id = f.periodid AND f.otherid = 17 WHERE p.companyid = 100
이 쿼리는 다음에서 데이터를 검색합니다. 'id' 및 '주기 ID' 열에 왼쪽 외부 조인을 적용하는 '기간' 및 '사실' 테이블. 또한 결과를 필터링하기 위한 추가 조인 조건 'f.otherid = 17'이 포함되어 있습니다.
LINQ to SQL에서 왼쪽 외부 조인의 일반적인 구현에는 'DefaultIfEmpty()' 메서드 사용이 포함됩니다. . 그러나 추가 조인 조건을 수용하려면 접근 방식을 수정해야 합니다.
다음 LINQ 쿼리는 원하는 결과를 얻습니다.
from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in fg.Where(f => f.otherid == 17).DefaultIfEmpty() where p.companyid == 100 select f.value
여기서 '.Where()' 절, 'fg' 그룹화에서 행 선택이 'f.otherid =에 따라 필터링되도록 보장합니다. 17'.
또는 하위 쿼리를 활용할 수도 있습니다.
from p in context.Periods join f in context.Facts on p.id equals f.periodid into fg from fgi in (from f in fg where f.otherid == 17 select f).DefaultIfEmpty() where p.companyid == 100 select f.value
두 가지 접근 방식 모두 추가 조인 조건을 적용하면서 왼쪽 외부 조인을 성공적으로 수행하므로 보다 목표화된 데이터 검색이 가능합니다.
위 내용은 LINQ to SQL에서 여러 조인 조건을 사용하여 왼쪽 외부 조인을 어떻게 수행할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!