본문 바로가기

DB

정규화(Normalization)

728x90

정규화(Normalization)이란?

정규화의 기본 목표는 테이블 간에 중복된 데이터를 허용하지 않는다는 것이다. 중복된 데이터를 허용하지 않음으로써 무결성(Integrity)를 유지할 수 있으며, DB의 저장 용량 역시 줄일 수 있다.

제1 정규화(1NF)

테이블의 컬럼이 원자값(Atomic Value, 하나의 값)을 같도록 테이블을 분해하는 것이다.

제2 정규화(2NF)

제1 정규화를 진행한 테이블에 대해 완전 함수 종속을 만족하도록 테이블을 분해하는 것이다. 여기서 완전 함수 종속이라는 것은 기본키의 부분집합이 결정자가 되어선 안 된다는 것을 의미한다.

제3 정규화(3NF)

제2 정규화를 진행한 테이블에 대해 이행적 종속을 없애도록 테이블을 분해하는 것이다. 여기서 이행적 종속이라는 것은 A -> B, B-> C가 성립할 때 A -> C가 성립되는 것을 의미한다.

BCNF 정규화

제3 정규화를 진행한 테이블에 대해 모든 결정자가 후보키가 되도록 테이블을 분해하는 것이다.

제4 정규화(4NF)

BCNF를 만족한 상태에서 다치 종속성을 제거해야 한다.
애트리뷰트가 값이 원자값이 아닌 값을 여러개 갖는 릴레이션을 분해하여 애트리뷰트가 원자값을 갖도록 하는 정규형이다.

제5 정규화(5NF)

4NF를 만종한 상태에서 조인 종속성을 제거해야 한다.
만약 하나의 릴레이션을 여러 개의 릴레이션으로 무손실 분해했다가 다시 결합할 수 있다면 조인 종속이라고 한다.

[출처]

https://zzozzomin08.tistory.com/12

https://itwiki.kr/w/%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%B2%A0%EC%9D%B4%EC%8A%A4_%EC%A0%95%EA%B7%9C%ED%99%94#4NF

https://mangkyu.tistory.com/110

728x90

'DB' 카테고리의 다른 글

C#에서 MySQL 엑세스하기  (0) 2024.04.24
JOIN 종류  (0) 2023.12.05
SQL 튜닝  (0) 2023.11.24
[PostgreSQL] PREPARE  (0) 2022.12.26
[PostgreSQL] WITH ... AS / INSERT INTO ... ON CONFLICT ... DO UPDATE SET ...  (0) 2022.12.26