ER 모델-기본 개념

ER 모델은 데이터베이스의 개념적보기를 정의합니다. 실제 엔티티와 이들 간의 연관성을 중심으로 작동합니다. 뷰 수준에서 ER 모델은 데이터베이스 설계에 적합한 옵션으로 간주됩니다.

실재

엔터티는 쉽게 식별 할 수있는 애니메이션 또는 무생물의 실제 개체 일 수 있습니다. 예를 들어, 학교 데이터베이스에서 제공되는 학생, 교사, 수업 및 코스는 엔티티로 간주 될 수 있습니다. 이러한 모든 엔터티에는 ID를 제공하는 몇 가지 특성 또는 속성이 있습니다.

항목 집합은 유사한 유형의 항목 모음입니다. 엔티티 세트에는 속성이 유사한 값을 공유하는 엔티티가 포함될 수 있습니다. 예를 들어, 학생 세트에는 학교의 모든 학생이 포함될 수 있습니다. 마찬가지로 Teachers 세트에는 모든 학부에서 학교의 모든 교사가 포함될 수 있습니다. 엔티티 세트는 분리 될 필요가 없습니다.

속성

엔티티는 다음과 같은 속성으로 표현됩니다. attributes. 모든 속성에는 값이 있습니다. 예를 들어 학생 엔터티는 이름, 클래스 및 연령을 특성으로 가질 수 있습니다.

속성에 할당 할 수있는 도메인 또는 값 범위가 있습니다. 예를 들어, 학생의 이름은 숫자 값이 될 수 없습니다. 알파벳이어야합니다. 학생의 나이는 음수가 될 수 없습니다.

속성 유형

  • Simple attribute− 단순 속성은 더 이상 나눌 수없는 원자 값입니다. 예를 들어, 학생의 전화 번호는 10 자리 원자 값입니다.

  • Composite attribute− 복합 속성은 하나 이상의 단순 속성으로 구성됩니다. 예를 들어, 학생의 전체 이름에는 first_name과 last_name이있을 수 있습니다.

  • Derived attribute− 파생 속성은 물리적 데이터베이스에 존재하지 않는 속성이지만 해당 값은 데이터베이스에있는 다른 속성에서 파생됩니다. 예를 들어 부서의 average_salary는 데이터베이스에 직접 저장해서는 안되며 대신 파생 될 수 있습니다. 다른 예로, 나이는 data_of_birth에서 파생 될 수 있습니다.

  • Single-value attribute− 단일 값 속성은 단일 값을 포함합니다. 예 : Social_Security_Number.

  • Multi-value attribute− 다중 값 속성은 둘 이상의 값을 포함 할 수 있습니다. 예를 들어, 한 사람이 둘 이상의 전화 번호, 이메일 주소 등을 가질 수 있습니다.

이러한 속성 유형은 다음과 같은 방식으로 함께 올 수 있습니다.

  • 단순 단일 값 속성
  • 단순 다중 값 속성
  • 복합 단일 값 속성
  • 복합 다중 값 속성

엔티티 세트 및 키

키는 엔터티 집합에서 엔터티를 고유하게 식별하는 특성 또는 특성 모음입니다.

예를 들어, 학생의 roll_number는 학생이 학생을 식별 할 수 있도록합니다.

  • Super Key − 엔티티 세트에서 엔티티를 집합 적으로 식별하는 속성 세트 (하나 이상).

  • Candidate Key− 최소 수퍼 키를 후보 키라고합니다. 엔티티 세트는 둘 이상의 후보 키를 가질 수 있습니다.

  • Primary Key − 기본 키는 개체 집합을 고유하게 식별하기 위해 데이터베이스 설계자가 선택한 후보 키 중 하나입니다.

관계

엔티티 간의 연관을 관계라고합니다. 예를 들어, 직원works_at 학과, 학생 enrolls코스에서. 여기서 Works_at 및 Enrolls를 관계라고합니다.

관계 세트

유사한 유형의 관계 집합을 관계 집합이라고합니다. 엔터티와 마찬가지로 관계도 속성을 가질 수 있습니다. 이러한 속성은descriptive attributes.

관계의 정도

관계에 참여하는 엔터티의 수는 관계의 정도를 정의합니다.

  • 이진 = 차수 2
  • 삼항 = 차수 3
  • n 항 = 학위

카디널리티 매핑

Cardinality 관계 집합을 통해 다른 집합의 엔터티 수와 연결할 수있는 한 엔터티 집합의 엔터티 수를 정의합니다.

  • One-to-one − 엔티티 세트 A의 하나의 엔티티는 엔티티 세트 B의 최대 하나의 엔티티와 연관 될 수 있으며 그 반대의 경우도 마찬가지입니다.

  • One-to-many − 엔티티 세트 A의 하나의 엔티티는 엔티티 세트 B의 둘 이상의 엔티티와 연관 될 수 있지만 엔티티 세트 B의 엔티티는 최대 하나의 엔티티와 연관 될 수 있습니다.

  • Many-to-one − 엔티티 세트 A의 하나 이상의 엔티티는 엔티티 세트 B의 최대 하나의 엔티티와 연관 될 수 있지만 엔티티 세트 B의 엔티티는 엔티티 세트 A의 둘 이상의 엔티티와 연관 될 수 있습니다.

  • Many-to-many − A의 하나의 엔티티는 B의 둘 이상의 엔티티와 연관 될 수 있으며 그 반대의 경우도 마찬가지입니다.