>백엔드 개발 >C++ >LINQ to SQL에서 여러 조인 조건을 사용하여 왼쪽 외부 조인을 어떻게 수행할 수 있습니까?

LINQ to SQL에서 여러 조인 조건을 사용하여 왼쪽 외부 조인을 어떻게 수행할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-29 20:02:15563검색

How Can I Perform a Left Outer Join with Multiple Join Conditions in LINQ to SQL?

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

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