엔티티에 대한 LINQ : 쿼리로 매핑 된 엔티티를 구성
이 기사는 LINQ에서 엔티티 쿼리 내의 매핑 된 엔티티에 사용자 정의 선택을 투사하려고 시도 할 때 발생하는 일반적인 오류를 다룹니다.
문제 이해
오류 "엔티티는 LINQ에서 엔티티 쿼리로 구성 될 수 없습니다"쿼리의 엔티티와 같은)의 새 인스턴스를 작성하려고 할 때 발생합니다. 속성의 하위 집합
예와 설명 :
이 코드 스 니펫을 고려하십시오
이것은 속성 만 포함 된 새로운 객체를 만들려고 시도합니다. Linq to Entities는 데이터 모델에 정의 된대로
엔티티의 모든 속성을 채워야하기 때문에 효율적인 데이터베이스 쿼리로 직접 변환 할 수 없습니다.
솔루션 : 익명 유형 및 dtos Product
이를 해결하려면 익명 유형 또는 데이터 전송 개체 (DTOS)를 사용하십시오.
select
익명 유형 :
필요한 속성 만 포함하는 익명 유형으로 프로젝트 :
이것은 각각 속성을 가진 익명 객체의
를 반환합니다.
dtos (데이터 전송 개체) :
원하는 데이터 구조를 나타내는 별도의 클래스 생성 :
<code class="language-csharp">public IQueryable<product> GetProducts(int categoryID)
{
return from p in db.Products
where p.CategoryID == categoryID
select new Product { Name = p.Name };
}</code>
이 접근법은 Product
객체의 강력한 결과 세트를 제공합니다. 특히 복잡한 데이터 구조를 다룰 때 더 나은 코드 유지 관리 및 가독성을 위해 DTOS를 선호합니다.
두 방법 모두 LINQ 내에서 엔티티 쿼리에 효율적인 사용자 정의 투영이 가능하여 원래 오류를 피할 수 있습니다. 프로젝트의 요구와 코딩 스타일에 가장 적합한 접근 방식을 선택하십시오. Name
위 내용은 LINQ에서 엔티티 쿼리에 매핑 된 엔티티를 구성 할 수없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!