[Database] 관계 데이터 모델의 개념, 릴레이션 스키마와 인스턴스
- DB
- 2018. 6. 29.
관계 데이터 모델
관계 데이터 모델은 수학의 집합이론에 근거하고 있어 튼튼한 이론적인 토대를 갖고 있다. 또한 관계 데이터 모델이 적용된 SQL 언어는 비절차적인 언어로 원하는 데이터를 쉽게 표현하는 장점이 있다.
릴레이션(relation)
관계 데이터 모델을 이해하기 위해서는 우선 가장 중요한 용어인 릴레이션에 대한 이해가 필요하다. 릴레이션은 행과 열로 구성된 테이블을 말한다. 릴레이션은 번역하면 친척, 관계라고 하지만 relationship도 관계여서 충돌을 피하기 위해 릴레이션이라고 그대로 부르고 있다. 그러나 relational data model, relational database 등은 관계 데이터 모델, 관계 데이터베이스라고 한다.
릴레이션 스키마와 인스턴스
릴레이션은 스키마와 인스턴스로 이루어진다. 스키마는 관계 데이터베이스의 릴레이션이 어떻게 구성되는지 어떤 정보를 담고 있는지에 대한 기본적인 구조를 정의한다. 테이블에서 스키마는 테이블의 첫 행인 헤더에 나타나며 각 데이터의 특징을 나타내는 속성, 자료타입 등의 정보를 담고 있다. 인스턴스는 정의된 스키마에 따라 테이블에 실제로 저장되는 데이터의 집합을 의미한다.
릴레이션 스키마
릴레이션 스키마는 릴레이션에 어떤 정보가 담길지를 정의한다. 도서 릴레이션은 도서번호, 도서이름, 출판사, 가격이라는 정보를 정의하고 있는데, 각 열을 속성(attribute)이라고 한다. 속성에는 각각의 이름이 있으며 우리는 그 이름을 보고 어떤 정보가 담기는 알 수 있다. 하지만 컴퓨터는 속성만으로 어떤 타입의 데이터인지 알 수 없다. 따라서 각 속성들이 어떤 값을 가질 수 있는지를 도메인(domain)이라는 용어를 사용하여 정의한다. 또한 릴레이션이 몇 개의 속성을 가지는가를 나타내기 위해 차수(degree)라는 용어를 사용한다.
- 속성(attribute) : 릴레이션 스키마의 열
- 도메인(domain) : 속성이 가질 수 있는 값의 집합
- 차수(degree) : 속성의 개수
- 투플(tuple) : 릴레이션의 행
- 카디날리티(cardinality) : 투플의 수
릴레이션의 특징
- 속성은 단일 값을 가진다 : 각 속성의 값은 도메인에 정의된 값만을 가지며 그 값은 모두 단일 값이어야 한다.
- 속성은 서로 다른 이름을 가진다.
- 한 속성의 값은 모두 같은 도메인 값을 가진다.
- 속성의 순서는 상관없다.
- 릴레이션 내의 중복된 투플은 허용하지 않는다.
- 투플의 순서는 상관없다.
'DB' 카테고리의 다른 글
[Database] 트랜잭션의 정의와 수행진행, 트랜잭션의 성질 ACID를 알아보자 (0) | 2018.06.30 |
---|---|
[Database] 제약조건의 종류와 데이터의 삽입, 삭제, 수정 시 여러 가지 제약조건의 수행에 대해 알아보자 (0) | 2018.06.29 |
[Database] 각 키에 대해서 공부하고 기본키와 외래키의 특징을 알아보자 (0) | 2018.06.29 |
[Database] 데이터베이스 시스템, 언어, 사용자의 개념과 DBMS 정의, 기능, 데이터베이스 구조와 데이터 독립성 알아보기 (0) | 2018.06.19 |
[Database] 데이터, 정보, 지식의정의와 데이터베이스 정의, 개념, 특징 (0) | 2018.06.19 |