- 강제이동
- 하드 마이그레이션
- 타임피커
- 하드 윈도우 복사
- javascript redirection
- XSS방어
- javascript 바코드 생성
- asp.net Select
- 파일업로드 유효성체크
- jquery 바코드
- XSS PHP
- 404에러페이지
- javascript 유효성체크
- ViewBag
- javascript 바코드스캔
- SSD 복사
- 맥 오라클설치
- 바코드 생성하기
- php 캐쉬제거
- 말줄임표시
- TempData
- jquery 바코드생성
- 파일업로드 체크
- django 엑셀불러오기
- ASP.Net Core 404
- 바코드 스캔하기
- asp.net core Select
- asp.net dropdownlist
- Mac Oracle
- ViewData
웹개발자의 기지개
[C#] .NET Core - Entity Framework Core 2 (Talk, TalkComment with FK 예제) 본문
[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
닷넷의 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
'ASP.NET > C#' 카테고리의 다른 글
[c#] 유동변수 (변수의 변수) (0) | 2023.03.05 |
---|---|
[C#] Guid 전역 고유한 키값 생성하기 (0) | 2022.11.18 |
[C#] .NET Core - Entity Framework Core 1 (0) | 2020.12.19 |
[C#] string.IsNullOrEmpty 와 string.IsNullOrWhiteSpace (0) | 2020.10.10 |
델리게이트 Delegate 연습2 (이벤트) (0) | 2019.11.16 |