>백엔드 개발 >C++ >메모리 내 컬렉션을 사용할 때 LINQ JOIN이 실패하는 이유는 무엇입니까?

메모리 내 컬렉션을 사용할 때 LINQ JOIN이 실패하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2025-01-17 23:41:12814검색

Why Does My LINQ JOIN Fail When Using an In-Memory Collection?

LINQ 조인 및 메모리 내 컬렉션 문제 해결

메모리 내 컬렉션(이 예의 ppCombined 등)을 직접 통합하려고 하면 "유형의 상수 값을 생성할 수 없습니다. 이 컨텍스트에서는 기본 유형 또는 열거 유형만 지원됩니다."라는 오류가 자주 나타납니다. 데이터베이스 LINQ 쿼리로. 이는 데이터베이스 쿼리가 데이터베이스 상주 데이터에서만 작동하기 때문입니다. 인메모리 데이터와의 조인은 직접 지원되지 않습니다.

문제는 일반적으로 Select 문의 Join 절 내에서 나타납니다. 메모리 내 컬렉션에서 채워진 속성을 포함하여 PersonDTO 개체를 생성하려고 하면 충돌이 발생합니다.

LINQ JOIN 실패의 근본 원인

이 오류는 데이터베이스 쿼리의 WhereppCombined 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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