Include 메서드로 관련 데이터 조회
추천 자료: ASP.NET Core 인증 및 권한 부여
EF Core를 사용하여 관련 테이블 데이터를 가져오기
이 아티클에서는 EF Core를 사용하여 관련 테이블 데이터를 가져오는 방법에 대해 설명합니다. 아래 예제에서는 'Broth', 'Noodle' 및 'Garnish'라는 세 가지 모델 클래스를 사용하여 데이터를 조인하여 가져옵니다.
참고로, 이 세 가지 모델 클래스는 Blazor Server 7.0 Fundamentals 강의 소스에 포함된 내용입니다.
- 모델 클래스 정의:
이 예제에서는 이미 세 가지 모델 클래스가 정의되어 있습니다. 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; }
// ... 다른 속성
}
- 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; }
// ... 다른 구성
}
- 데이터를 가져오는 방법:
Include
메서드를 사용하여 관련 테이블 데이터를 가져올 수 있습니다. 아래 예제에서는 국수와 관련된 국물과 고명 정보를 가져오는 방법을 보여줍니다.
using (var context = new BuffetDbContext())
{
var noodlesWithBrothsAndGarnishes = context.Noodles
.Include(n => n.Broth)
.Include(n => n.Garnishes)
.ToList();
}
- 필터링 및 정렬:
Where
및 OrderBy
메서드를 사용하여 결과를 필터링하고 정렬할 수 있습니다.
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
메서드를 사용하면 한 번의 쿼리로 관련 테이블의 데이터를 가져올 수 있습니다. 이를 통해 국수, 국물, 고명과 같은 관련된 데이터를 쉽게 추출할 수 있습니다.
추천 자료: .NET Blazor에 대해 알아보시겠어요? .NET Blazor 알아보기를 확인해보세요!