Entity Framework-유효성 검사

이 장에서는 ADO.NET Entity Framework에서 모델 데이터의 유효성을 검사하는 데 사용할 수있는 유효성 검사 기술에 대해 알아 봅니다. Entity Framework는 클라이언트 쪽 유효성 검사를 위해 사용자 인터페이스에 구현하거나 서버 쪽 유효성 검사에 사용할 수있는 매우 다양한 유효성 검사 기능을 제공합니다.

  • Entity Framework에서 데이터 유효성 검사는 응용 프로그램에서 잘못된 데이터를 포착하기위한 솔루션의 일부입니다.

  • Entity Framework는 광범위한 데이터 유효성 검사 방법을 사용하여 기본적으로 데이터베이스에 기록되기 전에 모든 데이터의 유효성을 검사합니다.

  • 그러나 Entity Framework는 사용자 인터페이스 데이터 유효성 검사 후에 제공됩니다. 따라서이 경우 EF가 throw하는 예외를 처리하고 일반 메시지를 표시하기 위해 엔터티 유효성 검사가 필요합니다.

  • 오류 검사를 개선하고 오류 메시지를 사용자에게 다시 전달하는 방법을위한 데이터 유효성 검사 기술이 있습니다.

DbContext에는 ValidateEntity라는 Overridable 메서드가 있습니다. SaveChanges를 호출하면 Entity Framework는 상태가 Unchanged가 아닌 캐시의 각 엔터티에 대해이 메서드를 호출합니다. Student Entity에 대한 다음 예제와 같이 여기에 유효성 검사 논리를 직접 넣을 수 있습니다.

public partial class UniContextEntities : DbContext {

   protected override System.Data.Entity.Validation
      .DbEntityValidationResult ValidateEntity(DbEntityEntry entityEntry, 
      System.Collections.Generic.IDictionary<object, object> items) {

         if (entityEntry.Entity is Student) {

            if (entityEntry.CurrentValues.GetValue<string>("FirstMidName") == "") {

               var list = new List<System.Data.Entity
                  .Validation.DbValidationError>();

               list.Add(new System.Data.Entity.Validation
                  .DbValidationError("FirstMidName", "FirstMidName is required"));

               return new System.Data.Entity.Validation
                  .DbEntityValidationResult(entityEntry, list);
            }
         }

         if (entityEntry.CurrentValues.GetValue<string>("LastName") == "") {

            var list = new List<System.Data.Entity
               .Validation.DbValidationError>();

            list.Add(new System.Data.Entity.Validation
               .DbValidationError("LastName", "LastName is required"));

            return new System.Data.Entity.Validation
               .DbEntityValidationResult(entityEntry, list);
         }

         return base.ValidateEntity(entityEntry, items);
   }
}

위 ValidateEntity 메서드에서 Student 엔터티 FirstMidName 및 LastName 속성은 이러한 속성에 빈 문자열이있는 경우 확인 된 다음 오류 메시지를 반환합니다.

새 학생이 생성되었지만 다음 코드와 같이 학생의 FirstMidName이 빈 문자열 인 간단한 예를 살펴 보겠습니다.

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         Console.WriteLine("Adding new Student to the database");
         Console.WriteLine();

         try {

            context.Students.Add(new Student() {
               FirstMidName = "",
               LastName = "Upston"
            });

            context.SaveChanges();
         } catch (DbEntityValidationException dbValidationEx) {

            foreach (DbEntityValidationResult entityErr in 
               dbValidationEx.EntityValidationErrors) {

               foreach (DbValidationError error in entityErr.ValidationErrors) {
                  Console.WriteLine("Error: {0}",error.ErrorMessage);
               }
            }
         }

         Console.ReadKey();
      }
   }
}

위의 예제를 컴파일하고 실행하면 콘솔 창에 다음과 같은 오류 메시지가 나타납니다.

Adding new Student to the database  
Error: FirstMidName is required

더 나은 이해를 위해 위의 예를 단계별로 실행하는 것이 좋습니다.