Entity Framework-Enum 지원

Entity Framework에서이 기능을 사용하면 열거 형 유형 인 도메인 클래스에 속성을 정의하고이를 정수 유형의 데이터베이스 열에 매핑 할 수 있습니다. 그런 다음 Entity Framework는 데이터를 쿼리하고 저장할 때 관련 열거 형간에 데이터베이스 값을 변환합니다.

  • 열거 형 유형은 응답 수가 고정 된 속성으로 작업 할 때 모든 종류의 이점이 있습니다.

  • 열거 형을 사용하면 응용 프로그램의 보안과 안정성이 모두 향상됩니다.

  • 열거를 사용하면 사용자가 실수를하기가 훨씬 더 어려워지고 주입 공격과 같은 문제가 존재하지 않습니다.

  • Entity Framework에서 열거 형은 다음과 같은 기본 유형을 가질 수 있습니다.

    • Byte
    • Int16
    • Int32
    • Int64
    • SByte
  • 열거 형 요소의 기본 기본 유형은 int입니다.

  • 기본적으로 첫 번째 열거 자의 값은 0이고 연속되는 각 열거 자의 값은 1 씩 증가합니다.

디자이너에서 엔터티를 만들고 몇 가지 속성을 추가하는 다음 예제를 살펴 보겠습니다.

Step 1 − 파일 → 새로 만들기 → 프로젝트 메뉴 옵션에서 새 프로젝트를 생성합니다.

Step 2 − 왼쪽 창에서 콘솔 애플리케이션을 선택합니다.

Step 3 − 프로젝트 이름으로 EFEnumDemo를 입력하고 확인을 클릭합니다.

Step 4 − 솔루션 탐색기에서 프로젝트 이름을 마우스 오른쪽 버튼으로 클릭하고 추가 → 새 항목 메뉴 옵션을 선택합니다.

Step 5 − 템플릿 창에서 ADO.NET 엔티티 데이터 모델을 선택합니다.

Step 6 − 파일 이름으로 EFEnumModel.edmx를 입력하고 추가를 클릭합니다.

Step 7 − 엔티티 데이터 모델 마법사 페이지에서 빈 EF 디자이너 모델을 선택합니다.

Step 8 − 마침 클릭

Step 9 − 그런 다음 디자이너 창을 마우스 오른쪽 버튼으로 클릭하고 추가 → 엔티티를 선택합니다.

다음 이미지와 같이 새 엔터티 대화 상자가 나타납니다.

Step 10 − 엔티티 이름으로 부서를 입력하고 속성 이름으로 DeptID를 입력하고 속성 유형을 Int32로두고 확인을 클릭합니다.

Step 11 − 엔티티를 마우스 오른쪽 버튼으로 클릭하고 새로 추가 → 스칼라 속성을 선택합니다.

Step 12 − 새 속성의 이름을 DeptName으로 변경합니다.

Step 13 − 새 속성의 유형을 Int32로 변경합니다 (기본적으로 새 속성은 문자열 유형입니다).

Step 14 − 유형을 변경하려면 속성 창을 열고 유형 속성을 Int32로 변경합니다.

Step 15 − Entity Framework Designer에서 Name 속성을 마우스 오른쪽 버튼으로 클릭하고 Convert to enum을 선택합니다.

Step 16 − Add Enum Type 대화 상자에서 Enum Type Name에 DepartmentNames를 입력하고 Underlying Type을 Int32로 변경 한 다음 Physics, Chemistry, Computer, Economics와 같은 멤버를 유형에 추가합니다.

Step 17 − 확인을 클릭합니다.

모델 브라우저 창으로 전환하면 유형이 Enum 유형 노드에도 추가 된 것을 볼 수 있습니다.

Model First 접근 방식 장에서 언급 한 모든 단계에 따라 모델에서 데이터베이스를 생성 해 보겠습니다.

Step 1 − Entity Designer 화면을 마우스 오른쪽 버튼으로 클릭하고 모델에서 데이터베이스 생성을 선택합니다.

데이터베이스 생성 마법사의 데이터 연결 선택 대화 상자가 표시됩니다.

Step 2 − 새 연결 버튼을 클릭합니다.

Step 3 − 데이터베이스의 서버 이름과 EnumDemo를 입력하고 확인을 클릭합니다.

Step 4 − 새 데이터베이스를 생성 할 것인지 묻는 대화 상자가 나타나면 예를 클릭합니다.

Step 5− 다음을 클릭하면 데이터베이스 생성 마법사가 데이터베이스 생성을위한 데이터 정의 언어 (DDL)를 생성합니다. 이제 마침을 클릭하십시오.

Step 6 − T-SQL 편집기를 마우스 오른쪽 버튼으로 클릭하고 실행을 선택합니다.

Step 7 − 생성 된 스키마를 보려면 SQL Server 개체 탐색기에서 데이터베이스 이름을 마우스 오른쪽 버튼으로 클릭하고 새로 고침을 선택합니다.

데이터베이스에 Departments 테이블이 표시됩니다.

컨텍스트에 대한 몇 가지 새로운 부서 개체가 추가되고 저장되는 다음 예제를 살펴 보겠습니다. 그런 다음 컴퓨터 부서를 검색하십시오.

class Program {

   static void Main(string[] args) {

      using (var context = new EFEnumModelContainer()) {

         context.Departments.Add(new Department { DeptName = DepartmentNames.Physics});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Computer});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Chemistry});
         context.Departments.Add(new Department { DeptName = DepartmentNames.Economics});

         context.SaveChanges();

         var department = (
            from d in context.Departments
            where d.DeptName == DepartmentNames.Computer
            select d
         ).FirstOrDefault();

         Console.WriteLine(
            "Department ID: {0}, Department Name: {1}", 
               department.DeptID, department.DeptName
         );

         Console.ReadKey();
      }
   }
}

위의 코드가 실행되면 다음과 같은 출력을 받게됩니다.

Department ID: 2, Department Name: Computer

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