Table(Relation)
- 행과 열의 2차원 구조를 가진 데이터 저장 객체
Column(Field, Attribute)
Row(Record, Tuple)
- 테이블에서 가로 방향으로 이루어진 연결된 데이터
Relational Model Constraints
1) 도메인 제약 => 속성에 대한 제약
- 속성 값은 원자성을 가지며 도메인에서 정의된 값이어야 함.
NOT NULL
이 아닌 경우 NULL
값은 허용됨.
Composite attribute
와 multivalued attribute
는 허용되지 않음.
data:image/s3,"s3://crabby-images/1769e/1769e9adcee9fe9cbf0c8956df1f902dea530cb0" alt=""
2) 키 제약 => 릴레이션에 대한 제약
- 릴레이션의 모든 튜플은 서로 식별 가능해야 함.
data:image/s3,"s3://crabby-images/837a4/837a48a81cd6e97bf89216b740d5510851cf0eba" alt=""
cf) Super Key, Candidate Key, Primary Key
3) 개체 무결성 제약 => 기본키(Primary Key)에 대한 제약
- 기본키는
Unique
& Not Null
이어야 함.
data:image/s3,"s3://crabby-images/a48b3/a48b3285b4d7e77f5a44928f599bfc235b82244f" alt=""
4) 참조 무결성 제약 => 외래키(Foreign Key)에 대한 제약
- 릴레이션 R1이 릴레이션 R2를 참조하는 경우, R2의 기본키는 R1에서 외래키로 사용됨.
- 외래키는 자기 자신이 속한 릴레이션을 참조할 수도 있음.
NULL
이거나 NULL
이 아닌 경우 R2에 실제로 존재하는 값으로 구성되어야 함.
data:image/s3,"s3://crabby-images/e72ac/e72ac46160cece4955deba06cc65bb26eb91ade9" alt=""
ER-to-Relational Model 변환 규칙
data:image/s3,"s3://crabby-images/e4218/e421888e90d140f76f6c6919f4022305f8301f5a" alt=""
Step 1: Mapping of Strong Entity Types
- 각 strong entity E에 대응되는 릴레이션 R을 생성함.
- E의 Single-valued/Simple/Stored attributes를 모두 R의 속성으로 포함시킴.
- Composite Attributes의 경우 각 하위 컴포넌트만 포함시킴.
- Multivalued Attributes는 추후 고려.
- E의 키 속성 중 하나를 선택하여 R의 기본키(Primary Key)로 정함.
- Composite Key의 경우, 이에 속한 속성들의 조합이 R의 기본키가 됨.
data:image/s3,"s3://crabby-images/868a2/868a284213891a7b18bd4f659a176fc8b0779166" alt=""
Step 2: Mapping of Weak Entity Types
- 각 weak entity W에 대응되는 릴레이션 R을 생성하고, W의 Single-valued/Simple/Stored attributes를 모두 R의 fields로 포함시킴.
- W의 식별 개체 E에 대해서, E의 기본키를 R의 외래키로 포함시킴.
- R의 기본키는 E의 기본키와 W의 부분키(Partial Key)의 조합으로 구성.
data:image/s3,"s3://crabby-images/8e864/8e864255f85456d322771187052e39b86141ef79" alt=""
Step 3: Mapping of Binary 1:N Relationship Types
- 각 Binary 1:N Relationship RS에 대해, 이 Relationship에 참여하는 두 entity를 각각 S(N-side)와 T(1-side)라고 하면 T의 기본키를 S의 외래키로 포함. RS에 속한 모든 simple attributes S에 포함시킴.
data:image/s3,"s3://crabby-images/d1046/d10462f3338a6b3fff7638310a5ec43d1ac72d10" alt=""
Step 4: Mapping of Binary 1:1 Relationship Types
- 각 Binary 1:1 Relationship RS에 대해, 이 Relationship에 참여하는 두 entity를 각각 S와 T라고 하면:
- (대안 1) T -> S 방향
- T의 기본키를 S의 외래키로 포함
- RS에 속한 모든 simple attributes를 S에 포함시킴.
- (대안 2) ST 방향
- S의 기본키를 T의 외래키로 포함
- RS에 속한 모든 simple attributes를 T에 포함시킴.
data:image/s3,"s3://crabby-images/1699a/1699a29a5a9c4beb6ce8cd704848a13f2ec32c65" alt=""
Step 5: Mapping of Binary M:N Relationship Types
- 각 Binary M:N Relationship RS에 대해, 이 Relationship에 참여하는 두 entity를 각각 S와 T라고 하면:
- RS에 대응되는 새로운 릴레이션 R을 생성함.
- RS에 속한 모든 simple attributes를 R에 포함시킴.
- S와 T의 기본키를 R의 외래키로 포함.
- R의 기본키는 S에서 온 외래키와 T에서 온 외래키의 조합으로 구성.
data:image/s3,"s3://crabby-images/74be5/74be58bb066a4d2277d7e2d25c699d9b8232f2ab" alt=""
Step 6: Mapping of N-ary Relationship Types
- 각 N-ary Relationship RS에 대해, 새로운 릴레이션 R을 생성함 (N>2인 경우에 해당됨).
- RS의 모든 simple attributes를 R의 속성으로 포함시킴.
- RS에 참여하는 모든 entity의 기본키를 R의 외래키로 포함시킴.
- R의 기본키는 모든 외래키의 조합으로 구성됨. 단, 대응수가 1인 관계로부터 가져온 외래키는 기본키의 조합에서 빠짐.
data:image/s3,"s3://crabby-images/1d96a/1d96a69f95283b91247a4ef563345acafd83bb36" alt=""
Step 7: Mapping of Multivalued attributes
- Entity E에 속한 multivalued attribute MA에 대해 릴레이션 R 생성.
- MA의 속성을 R에 포함시킴 (attribute A).
- E의 기본키 K를 R의 외래키로 포함시킴.
- R의 기본키는 K와 A의 조합으로 구성됨.
data:image/s3,"s3://crabby-images/7ab56/7ab563e230762d34105d0c08a0973230262ae001" alt=""
주의: 중복 정보 발생
- 중복 정보 발생 시 update anomaly, insert anomaly, delete anomaly 발생 가능.
예시 Case
data:image/s3,"s3://crabby-images/0f4ef/0f4ef12bd7e6a8d54560b344725c34245760376c" alt=""