Entity Framework-지속성

이제 Entity Framework를 사용하면 애플리케이션의 모든 부분이 Entity Framework를 인식하지 않고도 Entity Framework의 이점을 누릴 수 있으며, 엔터티를 인프라에서 분리 할 수 ​​있습니다. 지속되는 방식 (데이터가 저장되는 위치 및 데이터가 개체간에 데이터를주고받는 방식)에 관계없이 비즈니스 규칙에 집중할 수있는 클래스를 만들 수 있습니다.

영구 무지 엔티티 생성

앞의 단락에서는 소비하는 데이터의 소스에 대한 자세한 정보가없는 방법을 설명했습니다. 이것은 지속성 무지의 본질을 강조하는데, 클래스와 그 주변의 많은 애플리케이션 계층이 데이터가 저장되는 방식에 관심이없는 경우입니다.

  • .NET 3.5 버전의 Entity Framework에서 기존 클래스를 사용하려면 EntityObject에서 파생되도록 강제로 수정해야했습니다.

  • .NET 4에서는 더 이상 필요하지 않습니다. Entity Framework 작업에 참여하기 위해 엔터티를 수정할 필요가 없습니다.

  • 이를 통해 느슨한 결합 및 우려 분리를 수용하는 애플리케이션을 구축 할 수 있습니다.

  • 이러한 코딩 패턴을 사용하면 클래스가 자신의 작업에만 관심이 있고 UI를 포함한 애플리케이션의 많은 계층이 Entity Framework API와 같은 외부 논리에 종속되지 않지만 이러한 외부 API는 우리와 상호 작용할 수 있습니다. 엔티티.

Entity Framework를 사용하여 엔터티를 유지할 때 두 가지 방법 (연결 및 연결 해제)이 있습니다. 두 가지 방법 모두 자체적으로 중요합니다. 연결된 시나리오의 경우 변경 내용은 컨텍스트에 의해 추적되지만 연결이 끊긴 시나리오의 경우 엔터티 상태에 대한 컨텍스트를 알려야합니다.

연결된 시나리오

연결된 시나리오는 엔티티가 데이터베이스에서 검색되고 동일한 컨텍스트에서 수정되는 경우입니다. 연결된 시나리오의 경우 Windows 서비스가 있고 해당 엔터티로 일부 비즈니스 작업을 수행한다고 가정하여 컨텍스트를 열고 모든 엔터티를 반복하고 비즈니스 작업을 수행 한 다음 변경 내용을 동일한 컨텍스트로 저장합니다. 처음에 열었습니다.

데이터베이스에서 학생을 검색하고 학생의 이름을 업데이트 한 다음 변경 사항을 데이터베이스에 저장하는 다음 예제를 살펴 보겠습니다.

class Program {

   static void Main(string[] args) {

      using (var context = new MyContext()) {

         var studentList = context.Students.ToList();

         foreach (var stdnt in studentList) {
            stdnt.FirstMidName = "Edited " + stdnt.FirstMidName;
         }

         context.SaveChanges();

         //// Display all Students from the database

         var students = (from s in context.Students
            orderby s.FirstMidName select s).ToList<Student>();

         Console.WriteLine("Retrieve all Students from the database:");

         foreach (var stdnt in students) {
            string name = stdnt.FirstMidName + " " + stdnt.LastName;
            Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
         }

         Console.ReadKey();
      }
   }
}

위의 코드가 컴파일되고 실행되면 다음 출력이 표시되고 다음 출력과 같이 이름 앞에 편집 된 단어가 첨부 된 것을 볼 수 있습니다.

Retrieve all Students from the database: 
ID: 1, Name: Edited Edited Alain Bomer 
ID: 2, Name: Edited Edited Mark Upston

연결이 끊긴 시나리오

연결이 끊긴 시나리오는 엔티티가 데이터베이스에서 검색되고 다른 컨텍스트에서 수정되는 경우입니다. 프레젠테이션 레이어에 일부 데이터를 표시하고 n 계층 응용 프로그램을 사용하고 있으므로 컨텍스트를 열고 데이터를 가져온 다음 마지막으로 컨텍스트를 닫는 것이 좋습니다. 여기에서 데이터를 가져오고 컨텍스트를 닫았으므로 가져온 엔티티는 더 이상 추적되지 않으며 연결이 끊어진 시나리오입니다.

Add 메서드를 사용하여 연결이 끊긴 새로운 Student 엔터티가 컨텍스트에 추가되는 다음 코드를 살펴 보겠습니다.

class Program {

   static void Main(string[] args) {

      var student = new Student {
         ID = 1001, 
         FirstMidName = "Wasim", 
         LastName = "Akram", 
         EnrollmentDate = DateTime.Parse( DateTime.Today.ToString())
      };

      using (var context = new MyContext()) {

         context.Students.Add(student);
         context.SaveChanges();

         //// Display all Students from the database

         var students = (from s in context.Students 
            orderby s.FirstMidName select s).ToList<Student>();

         Console.WriteLine("Retrieve all Students from the database:");

         foreach (var stdnt in students) {
            string name = stdnt.FirstMidName + " " + stdnt.LastName;
            Console.WriteLine("ID: {0}, Name: {1}", stdnt.ID, name);
         }

         Console.ReadKey();
      }
   }
}

위의 코드가 컴파일되고 실행되면 다음과 같은 출력이 표시됩니다.

Retrieve all Students from the database:
ID: 1, Name: Edited Edited Edited Alain Bomer
ID: 2, Name: Edited Edited Edited Mark Upston
ID: 3, Name: Wasim Akram