Include 메서드로 관련 데이터 조회

  • 2 minutes to read

EF Core를 사용하여 관련 테이블 데이터를 가져오기

이 아티클에서는 EF Core를 사용하여 관련 테이블 데이터를 가져오는 방법에 대해 설명합니다. 아래 예제에서는 'Broth', 'Noodle' 및 'Garnish'라는 세 가지 모델 클래스를 사용하여 데이터를 조인하여 가져옵니다.

참고로, 이 세 가지 모델 클래스는 Blazor Server 7.0 Fundamentals 강의 소스에 포함된 내용입니다.

  1. 모델 클래스 정의:

이 예제에서는 이미 세 가지 모델 클래스가 정의되어 있습니다. Broth, Noodle, Garnish 클래스는 각각 국물, 국수, 고명에 대한 정보를 나타냅니다. 아래 코드에서 각 클래스의 정의를 참조하십시오.

// Broth.cs
public class Broth
{
    public int Id { get; set; }
    // ... 다른 속성
}

// Noodle.cs
public class Noodle
{
    public int Id { get; set; }
    public int? BrothId { get; set; }
    public Broth? Broth { get; set; }
    // ... 다른 속성
}

// Garnish.cs
public class Garnish
{
    public int Id { get; set; }
    public int? NoodleId { get; set; }
    public Noodle? Noodle { get; set; }
    // ... 다른 속성
}
  1. DbContext 클래스 정의:

DbContext 클래스를 정의하여 각 모델 클래스에 대한 DbSet 속성을 추가합니다.

public class BuffetDbContext : DbContext
{
    public DbSet<Broth> Broths { get; set; }
    public DbSet<Noodle> Noodles { get; set; }
    public DbSet<Garnish> Garnishes { get; set; }

    // ... 다른 구성
}
  1. 데이터를 가져오는 방법:

Include 메서드를 사용하여 관련 테이블 데이터를 가져올 수 있습니다. 아래 예제에서는 국수와 관련된 국물과 고명 정보를 가져오는 방법을 보여줍니다.

using (var context = new BuffetDbContext())
{
    var noodlesWithBrothsAndGarnishes = context.Noodles
        .Include(n => n.Broth)
        .Include(n => n.Garnishes)
        .ToList();
}
  1. 필터링 및 정렬:

WhereOrderBy 메서드를 사용하여 결과를 필터링하고 정렬할 수 있습니다.

using (var context = new BuffetDbContext())
{
    var veganNoodlesWithBrothsAndGarnishes = context.Noodles
        .Include(n => n.Broth)
        .Include(n => n.Garnishes)
        .Where(n => n.Broth.IsVegan)
        .OrderBy(n => n.Name)
        .ToList();
}

이 아티클에서는 EF Core를 사용하여 관련 테이블 데이터를 가져오는 방법을 설명했습니다. Include 메서드를 사용하면 한 번의 쿼리로 관련 테이블의 데이터를 가져올 수 있습니다. 이를 통해 국수, 국물, 고명과 같은 관련된 데이터를 쉽게 추출할 수 있습니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com