LINQ to SQL 쿼리에서 익명 형식을 반환하는 방법
LINQ to SQL을 사용하여 여러 테이블로 작업할 때 익명 유형을 반환하면 문제가 발생할 수 있습니다. 다음 예를 고려해보세요.
원래 방법:
<code class="language-csharp">public IQueryable<dog> GetDogs() { var db = new DogDataContext(ConnectString); var result = from d in db.Dogs join b in db.Breeds on d.BreedId equals b.BreedId select d; return result; }</code>
이 방법은 모든 개 정보를 성공적으로 검색합니다. 그러나 익명 유형을 사용하여 개와 품종 이름을 검색하려고 하면 다음과 같습니다.
<code class="language-csharp">public IQueryable<dog> GetDogsWithBreedNames() { var db = new DogDataContext(ConnectString); var result = from d in db.Dogs join b in db.Breeds on d.BreedId equals b.BreedId select new { Name = d.Name, BreedName = b.BreedName }; return result; }</code>
컴파일러는 익명 유형이 아닌 Dog 유형이 반환될 것으로 예상하기 때문에 오류가 발생합니다.
대안: 맞춤 클래스
한 가지 해결책은 DogWithBreed와 같은 사용자 정의 클래스를 만드는 것입니다.
<code class="language-csharp">public class DogWithBreed { public Dog Dog { get; set; } public string BreedName { get; set; } }</code>
그런 다음 코드를 다음과 같이 수정할 수 있습니다.
<code class="language-csharp">public IQueryable<DogWithBreed> GetDogsWithBreedNames() { var db = new DogDataContext(ConnectString); var result = from d in db.Dogs join b in db.Breeds on d.BreedId equals b.BreedId select new DogWithBreed() { Dog = d, BreedName = b.BreedName }; return result; }</code>
이 접근 방식은 추가 코딩 작업이 필요하지만 형식이 안전하고 재사용 가능한 솔루션을 제공합니다. 사용자 정의 클래스를 선택하면 익명 유형으로 인해 발생하는 유형 불일치 문제를 방지하고 코드의 유지 관리성과 가독성을 향상시킬 수 있습니다.
위 내용은 LINQ에서 SQL 쿼리로 익명 유형을 반환하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!