관리 메뉴

웹개발자의 기지개

[C#] .NET Core - Entity Framework Core 2 (Talk, TalkComment with FK 예제) 본문

ASP.NET/C#

[C#] .NET Core - Entity Framework Core 2 (Talk, TalkComment with FK 예제)

http://portfolio.wonpaper.net 2022. 10. 22. 14:44

[C#] .NET Core - Entity Framework Core 1 

 

[C#] .NET Core - Entity Framework Core 1

Entity Framework 를 활용해보자. 먼저 NuGet 으로 Entity Framework 관련 패키지를 설치해둔다. 아래의 그림과 같이 Employee.cs 와 MyDbContext.cs 클래스 파일을 준비한다. 1 2 3 4 5 6 7 8 9 10 11 12 13 1..

wonpaper.tistory.com

 

닷넷의 Entity FrameWork Core 예제를 통해 돌려보자.

TalkApp 이라는 기본 프로젝트를 만들고, TalkApp.Models 라는 별도의 추가 프로젝트를 만든다. (클래스라이브러리 프로젝트)

이때 TalkApp.Models 에서 Nuget패키지로 EntityFrameworkCore.Sqlserver 를 추가설치한다.

 

[ Talk.cs ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
using System.Collections.Generic;
using System.Text;
 
namespace TalkApp.Models
{
    public class Talk
    {
        public long Id { get; set; }
        public string Name { get; set; }
        public string Title { get; set; }
        public string Content { get; set; }
        public DateTime? Created { get; set; }
 
        public List<TalkComment> TalkComments { get; set; } = new List<TalkComment>();
        public string UserId { get; set; }
 
    }
}
 
cs

15라인과 같이 Talk 와 TalkComment  간의 1:다 관계형성을 위하여  코드를 추가해준다.

 

[ TalkComment.cs ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
 
namespace TalkApp.Models
{
    public class TalkComment
    {
        public long Id { get; set; }
        public string Name { get; set; }
        public string Title { get; set; }
        public string Content { get; set; }
        public DateTime? Created { get; set; }
        public string UserId { get; set; }
 
        // Talk 의 FK
        public long TalkId { get; set; }
        public Talk Talk { get; set; }
 
    }
}
 
cs

15,16라인처럼 Talk 와 TalkComment 간의 1:다 관계를 위해 FK 외래키를 지정해준다.

 

[ TalkAppDbContext.cs ]  - DB연동을 위한 Context 설정

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
using Microsoft.EntityFrameworkCore;
using System;
using System.Collections.Generic;
using System.Text;
 
namespace TalkApp.Models
{
    public class TalkAppDbContext : DbContext
    {
        protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
        {
            base.OnConfiguring(optionsBuilder);
            //optionsBuilder.UseInMemoryDatabase("TalkApp");
            optionsBuilder.UseSqlServer("Server=DESKTOP-ASIDMUS;Database=TalkApp;Trusted_Connection=True;MultipleActiveResultSets=true");
        }
        
        // Talks 와 TalkComnents 테이블 설정
        public DbSet<Talk> Talks { get; set; }
        public DbSet<TalkComment> TalkComments { get; set; }
    }
}
cs

13라인의 UseInMemoryDatabase 는 휘발성 메모리상의 DB 설정부분으로 프로젝트를 닫으면 없어지는 임시 메모리 디비라고 생각하면 된다. 

 

자~ 이제부터 EF Core 를 위한 모든 설정은 끝났다. 

다음 화면에서 실제로 실행해보도록 하자.

 

[ Program.cs ]

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
using System;
using System.Collections.Generic;
using System.Linq;
using TalkApp.Models;
 
namespace TalkApp
{
    internal class Program
    {
        static void Main(string[] args)
        {
            TalkAppDbContext context = new TalkAppDbContext();
            context.Database.EnsureCreated();
 
            // Insert
            Talk talk = new Talk() {Name = "홍길동"};
            context.Talks.Add(talk);
            context.Talks.Add(new Talk {Name="백두산"});
            context.SaveChanges();
 
            // Select
            List<Talk> talks = context.Talks.ToList();
            Console.WriteLine($"레코드 개수 : {talks.Count}");
            foreach (var t in talks)
            {
                Console.WriteLine($"{t.Id} - {t.Name}");
            }
        }
    }
}
 
cs

12라인처럼 DbContext 를 객체를 만들고,

13라인은 해당 DB (TalkApp ) 이 없으면 만들어준다.

 

그아래 코드처럼 Insert 실행을 위해서는 Query  문이 없어도 

context.Talks.Add(객체) 하면 자동적으로 insert 가 된다. 완전 간편~

이때 꼭 context.SaveChanges(); 를 해야 실제 테이블에 레코드가 만들어진다.

 

Select 문은 22라인처럼 context.Talks.ToList() 처럼 이 한문장으로 끝난다.

 

Ctrl + F5으로 결과를 확인해 보자.

 

 

참고1 : https://www.youtube.com/watch?v=Ja5mgA8YN4w&list=PLO56HZSjrPTA6sKgzv5DBdmsXjB42P2wl&index=30&t=369s 

참고2 : https://github.com/VisualAcademy

Comments