제 2 정규화

- 기본키 2개 이상으로 구성되는 테이블에서 일부 속성에 대해서만 부분적으로 함수 종속적인 것을 분리

- 즉, 부분함수 종속성을 제거해 준다 (만약 기본키가 하나 인 경우 제2정규화는 하지 않는다)


ex) 이전 포스팅에서 제1 정규화를 시킨 테이블 두개를 봅시다.

관련링크 : http://hahahia.tistory.com/147


제품 Table

제품번호 

제품명 

재고수량 

1001 

모니터 

2000 

1007 

마우스 

9000 

1201 

키보드 

2100 


제품 주문 Table

 주문번호

제품번호 

고객번호 

주소 

주문수량 

A345 

1001

100

서울

150 

D347 

1001

200 

부산 

300 

A210 

1007 

300 

광주 

600 

A345 

1007 

100 

서울 

400 

B230 

1007 

200

부산 

700 

D347 

1201 

200 

부산 

300 


먼저 제품 Table에서는 제품번호 하나만이 유일한 고유키값을 가지기 때문에 해당사항이 없습니다 ㅎㅎ

하지만 제품 주문 Table에서 함수적 종속이 존재하는데요.

------------------------------------------------------------------------

주문번호, 제품번호 -> 고객번호, 주소, 주문수량 (기본키니깐 당연하죠)

주문번호 -> 고객번호, 주소(부분종속!!)

------------------------------------------------------------------------

즉 고객번호와 주소는 제품번호(기본키중 하나)를 몰라도 알 수 있기 때문에 데이터 중복이 발생하는 것 입니다. 예를 들어 주소를 서울에서 인천으로 하나만 수정하려고 해도 모두 바꾸어 주어야 하기 때문에 중복이 되는거죠.

따라서 제품 목록 Table은 또 두개의 Table로 나눠서 처리할 수 있습니다.


주문 목록 Table

주문번호 

제품번호 

주문수량 

A345 

1001 

150 

D347 

1001 

300 

A210 

1007 

600 

A345 

1007 

400 

B230 

1007 

700 

D347 

1201 

300 


주문 Table 

주문번호

고객번호

주소 

A345 

100 

서울 

D347 

200 

부산 

A210 

300 

광주 

B230 

200 

부산 


일단 제 2 정규화 끝.




신고

'Database' 카테고리의 다른 글

제 3 정규화  (0) 2013.06.06
제 2 정규화  (0) 2013.06.06
제 1 정규화(Normal Form)  (1) 2013.06.06

+ Recent posts

티스토리 툴바