LINQ 조인 및 메모리 내 컬렉션 문제 해결
메모리 내 컬렉션(이 예의 ppCombined
등)을 직접 통합하려고 하면 "유형의 상수 값을 생성할 수 없습니다. 이 컨텍스트에서는 기본 유형 또는 열거 유형만 지원됩니다."라는 오류가 자주 나타납니다. 데이터베이스 LINQ 쿼리로. 이는 데이터베이스 쿼리가 데이터베이스 상주 데이터에서만 작동하기 때문입니다. 인메모리 데이터와의 조인은 직접 지원되지 않습니다.
문제는 일반적으로 Select
문의 Join
절 내에서 나타납니다. 메모리 내 컬렉션에서 채워진 속성을 포함하여 PersonDTO
개체를 생성하려고 하면 충돌이 발생합니다.
LINQ JOIN 실패의 근본 원인
이 오류는 데이터베이스 쿼리의 Where
문 ppCombined
내 Select
컬렉션에서 필터링 작업(
해결책: 데이터베이스 및 메모리 내 작업 분리
AsEnumerable()
해법은 데이터베이스 쿼리와 메모리 내 처리를 분리하는 것입니다. 여기에는 먼저 데이터베이스 쿼리를 실행한 다음 결과 메모리 내 데이터 세트에 대한 필터링 및 데이터 조작을 수행하는 작업이 포함됩니다. 여기서는 IEnumerable
방법이 핵심입니다. 데이터베이스 쿼리를 강제로 실행하여 결과를
수정된 코드는 다음과 같습니다.
<code class="language-csharp">var persons = db.Favorites .Where(f => f.userId == userId) .Join(db.Person, f => f.personId, p => p.personId, (f, p) => new { personId = p.personId, addressId = p.addressId, favoriteId = f.favoriteId }) .AsEnumerable() // Database query completes here .Select(x => new PersonDTO { personId = x.personId, addressId = x.addressId, favoriteId = x.favoriteId, personProtocol = ppCombined .Where(p => p.personId == x.personId) .Select(p => new PersonProtocol { personProtocolId = p.personProtocolId, activateDt = p.activateDt, personId = p.personId }) .ToList() });</code>
AsEnumerable()
Select
을 사용하면 데이터베이스 쿼리가 마무리되고 후속 ppCombined
문은 데이터베이스에서 검색된 데이터에만 작동하여 메모리 내
위 내용은 메모리 내 컬렉션을 사용할 때 LINQ JOIN이 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!