DB/[이론]

정규화 수행과정 #도부이결다조

씩씩한 IT블로그 2022. 3. 5. 19:50
반응형

정규화 수행과정

-1차 정규화 : 원자값 아닌 도메인 분해(도)

-2차 정규화 : 부분 함수 종속 제거(부)

-3차정규화 : 이행함수종속 제거(이)

-보이스-코드 정규화 : 결정자가 후보키가 아닌 것 제거(결)

-4차정규화 : 다치종속 제거(다)

-5차정규화 : 조인종속 제거(조)

 

1차 정규화

- 하나의 컬럼에 원자값을 갖도록 조정

- 예시

과목명을 분리하고, 학번+과목명을 기본키로

 

2차 정규화

- 부분함수 종속 제거

- 기본키의 일부가 다른 컬럼과 종속

- 예시

(학번, 과목코드)에서 과목코드가 과목명과 함수 종속관계이므로 분해한다.

 

3차 정규화

- 이행함수 종속

- 예시

학번->학부, 학부->등록금이므로 이를 3차 정규화 한다.

- 물론 학번->학부->등록금을 거치지 않고도, 등록금은 학부에 종속된다(학번에을 알면 해당 학생의 등록금을 무조건 알 수 있기 때문이다.) 하지만 의미적으로 등록금은 학부에 종속적으로 결정되는 것이 맞다. 따라서 이를 분리해 주어야 하는 것이다.

(https://yaboong.github.io/database/2018/03/09/database-normalization-1/ 블로그 참조!)

 

보이스-코드 정규화

- 결정자가 후보키가 아닌것 제거

- 예시

(학번,과목)이 후보키일 때 교수->과목 이 종속된다(교수가 한과목만 맡을때)

 

4차 정규화

- 다치종속 제거

- 하나의 속성이 두개이상의 속성에 대응하는것

사원번호->기술코드, 사원번호-> 프로젝트코드

 

5차 정규화

- 조인종속 제거

- A-B, A-C, B-C이지만 A-B-C는 아닌것

반응형