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 메서드를 사용하면 한 번의 쿼리로 관련 테이블의 데이터를 가져올 수 있습니다. 이를 통해 국수, 국물, 고명과 같은 관련된 데이터를 쉽게 추출할 수 있습니다.

VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com