>백엔드 개발 >C++ >LINQ에서 SQL 쿼리로 익명 유형을 반환하는 방법은 무엇입니까?

LINQ에서 SQL 쿼리로 익명 유형을 반환하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2025-01-28 00:16:09818검색

How to Return Anonymous Types from LINQ to SQL Queries?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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