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();
}