엔티티 프레임 워크 코어 : LINQ에서 엔티티 쿼리의 투영 제한
엔티티 프레임 워크 코어를 사용할 때 LINQ 로의 투영 내에 직접 엔티티 객체를 구성하는 경우 종종 오류가 발생합니다. "엔티티 또는 복잡한 유형은 LINQ에서 엔티티 쿼리에서 구성 할 수 없습니다.".
문제 :
<:>이 예를 고려하십시오 :
로 이것을 실행하는 것은 실패합니다
왜 실패하는지 :
문제는 엔티티 프레임 워크 코어가 LINQ 쿼리를 데이터베이스 명령으로 변환한다는 사실에서 비롯됩니다. 데이터베이스 서버에는 응용 프로그램의 클래스 및 생성자에 대한 지식이 부족합니다. 그러므로이 클래스의 인스턴스를 만들 수는 없습니다
솔루션 : 익명 유형 또는 DTOS 로 프로젝트
솔루션은 쿼리 결과를 익명 유형 또는 전용 데이터 전송 개체 (DTOS)로 투사하는 것입니다.
방법 1 : 익명 유형 사용
이것은 작은 쿼리를위한 빠르고 간단한 솔루션입니다.
방법 2 : 데이터 전송 객체 사용 (DTOS)
보다 복잡한 시나리오 또는 강하게 유형 된 객체가 필요할 때 DTO를 작성하십시오 :
<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>
익명 유형 또는 DTO로 투영함으로써 데이터베이스가 엔티티 클래스를 인스턴스화 할 필요성을 우회하여 성공적인 쿼리 실행을 보장합니다.위 내용은 LINQ에서 엔티티를 엔티티 투영으로 구성하는 이유는 왜 오류가 발생합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!