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의 둘 이상의 엔티티와 연관 될 수 있으며 그 반대의 경우도 마찬가지입니다.