Entity Framework-데이터베이스 작업
이전 장에서 엔티티 데이터 모델을 정의하는 세 가지 방법을 배웠습니다.
그 중 두 가지 인 Database First와 Model First는 코드 생성과 결합 된 Entity Framework 디자이너에 의존했습니다.
세 번째 인 Code First를 사용하면 비주얼 디자이너를 건너 뛰고 자신 만의 코드를 작성할 수 있습니다.
선택하는 경로에 관계없이 도메인 클래스로 끝나고 하나 이상의 Entity Framework DbContext 클래스를 사용하여 해당 클래스와 관련된 데이터를 검색하고 유지할 수 있습니다.
애플리케이션의 DbContext API는 클래스와 데이터베이스 간의 브리지로 사용됩니다. DbContext는 Entity Framework에서 가장 중요한 클래스 중 하나입니다.
쿼리를 표현하고 실행할 수 있습니다.
데이터베이스에서 쿼리 결과를 가져와 모델 클래스의 인스턴스로 변환합니다.
추가 및 삭제를 포함하여 엔터티의 변경 사항을 추적 한 다음 요청시 데이터베이스에 전송되는 삽입, 업데이트 및 삭제 문 생성을 트리거 할 수 있습니다.
다음은이 장에서 다른 작업을 수행 할 도메인 광고 컨텍스트 클래스입니다. 이것은 Database First Approach라는 chapater에서 만든 것과 동일한 예입니다.
컨텍스트 클래스 구현
using System;
using System.Data.Entity;
using System.Data.Entity.Infrastructure;
using System.Data.Entity.Core.Objects;
using System.Linq;
namespace DatabaseFirstDemo {
public partial class UniContextEntities : DbContext {
public UniContextEntities(): base("name = UniContextEntities") {}
protected override void OnModelCreating(DbModelBuilder modelBuilder) {
throw new UnintentionalCodeFirstException();
}
public virtual DbSet<Course> Courses { get; set; }
public virtual DbSet<Enrollment> Enrollments { get; set; }
public virtual DbSet<Student> Students { get; set; }
}
}
도메인 클래스 구현
코스 클래스
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Course {
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2214:DoNotCallOverridableMethodsInConstructors")]
public Course() {
this.Enrollments = new HashSet<Enrollment>();
}
public int CourseID { get; set; }
public string Title { get; set; }
public int Credits { get; set; }
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2227:CollectionPropertiesShouldBeReadOnly")]
public virtual ICollection<Enrollment> Enrollments { get; set; }
}
}
학생 수업
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Student {
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2214:DoNotCallOverridableMethodsInConstructors")]
public Student() {
this.Enrollments = new HashSet<Enrollment>();
}
public int ID { get; set; }
public string LastName { get; set; }
public string FirstMidName { get; set; }
public System.DateTime EnrollmentDate { get; set; }
[System.Diagnostics.CodeAnalysis.SuppressMessage("Microsoft.Usage",
"CA2227:CollectionPropertiesShouldBeReadOnly")]
public virtual ICollection<Enrollment> Enrollments { get; set; }
}
}
등록 클래스
namespace DatabaseFirstDemo {
using System;
using System.Collections.Generic;
public partial class Enrollment {
public int EnrollmentID { get; set; }
public int CourseID { get; set; }
public int StudentID { get; set; }
public Nullable<int> Grade { get; set; }
public virtual Course Course { get; set; }
public virtual Student Student { get; set; }
}
}
작업 생성
Entity Framework를 사용하여 새 개체를 추가하는 것은 개체의 새 인스턴스를 생성하고 DbSet에서 Add 메서드를 사용하여 등록하는 것처럼 간단합니다. 다음 코드를 사용하면 새 학생을 데이터베이스에 추가 할 수 있습니다.
class Program {
static void Main(string[] args) {
var newStudent = new Student();
//set student name
newStudent.FirstMidName = "Bill";
newStudent.LastName = "Gates";
newStudent.EnrollmentDate = DateTime.Parse("2015-10-21");
newStudent.ID = 100;
//create DBContext object
using (var dbCtx = new UniContextEntities()) {
//Add Student object into Students DBset
dbCtx.Students.Add(newStudent);
// call SaveChanges method to save student into database
dbCtx.SaveChanges();
}
}
}
업데이트 작업
기존 객체를 변경하는 것은 변경하려는 속성에 할당 된 값을 업데이트하고 SaveChanges를 호출하는 것만 큼 간단합니다. 예를 들어 다음 코드는 Ali의 성을 Khan에서 Aslam으로 변경하는 데 사용됩니다.
using (var context = new UniContextEntities()) {
var student = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
student.LastName = "Aslam";
context.SaveChanges();
}
작업 삭제
Entity Framework를 사용하여 엔터티를 삭제하려면 DbSet에서 Remove 메서드를 사용합니다. 제거는 기존 및 새로 추가 된 엔티티 모두에 대해 작동합니다. 추가되었지만 아직 데이터베이스에 저장되지 않은 엔티티에 대해 Remove를 호출하면 엔티티 추가가 취소됩니다. 엔티티가 변경 추적기에서 제거되고 더 이상 DbContext에 의해 추적되지 않습니다. 변경 추적중인 기존 엔티티에 대해 Remove를 호출하면 다음에 SaveChanges가 호출 될 때 삭제할 엔티티가 등록됩니다. 다음 예제는 이름이 Ali 인 데이터베이스에서 학생이 제거 된 코드입니다.
using (var context = new UniContextEntities()) {
var bay = (from d in context.Students where d.FirstMidName == "Ali" select d).Single();
context.Students.Remove(bay);
context.SaveChanges();
}
읽기 작업
데이터베이스에서 기존 데이터를 읽는 것은 매우 간단합니다. 다음은 Student 테이블에서 모든 데이터를 검색 한 다음 알파벳 순서로 학생의 성과 이름과 함께 프로그램이 표시되는 코드입니다.
using (var db = new UniContextEntities()) {
var query = from b in db.Students orderby b.FirstMidName select b;
Console.WriteLine("All All student in the database:");
foreach (var item in query) {
Console.WriteLine(item.FirstMidName +" "+ item.LastName);
}
Console.WriteLine("Press any key to exit...");
Console.ReadKey();
}