데이터베이스 공부를 하면서 중요한 개념이라 생각해서 포스팅합니다...


정규화(Normal Form)

- 관계형 데이터베이스의 설계에서 중복을 최소화하게 데이터를 구조화하는 프로세스

정규화의 목표는 이상이 있는 관계를 재구성하여 작고 잘 조직된 관계를 생성

- 데이터 무결성 유지 및 안정성 최대화

- 제1정규형, 제2정규형, 제3정규형, BCNF 등이 있다(나머지 정규형은 잘 안쓰인다고 함..)


ex) 주문 목록 Table

 제품번호

제품명 

재고수량 

주문번호 

고객번호 

주소 

주문수량 

1001 

모니터

2000 

A345

100 

서울 

150 

1001 

모니터 

2000

D347 

200 

부산 

300 

1007 

마우스 

9000 

A210 

300 

광주 

600 

1007 

마우스 

9000 

A345 

100 

서울 

400 

1007 

마우스 

9000 

B230 

200 

부산 

700 

1201 

키보드 

2100 

D347 

200 

부산 

300 


제1정규형

- 테이블에 있는 모든 속성의 도메인이 원자값(Atomic Value)만으로 되어있는 정규형. 

반복되는 그룹 속성이 존재할 경우 그 그룹을 분리하여 새로운 Entity 타입을 추가한후 기존의 실체와 1:N의 관계를 형성해 준다(여기서는 제품명, 재고수량, 주문번호가 중복되네요)

- 그리고 위 테이블에서는 하나의 제품에 대해 여러 개의 주문 관련 정보(주문번호, 고객번호, 주소 ,주문수량) 발생

따라서 주문 목록 Table은 제1정규형이 아님.

제1정규형으로 고치게 된다면...


제품 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 

제품 주문 테이블에서 제품번호는 PK(Primary Key)이자 제품 Table의 FK(Foreign Key)가 됩니다. ㅎㅎ




신고

'Database' 카테고리의 다른 글

제 3 정규화  (0) 2013.06.06
제 2 정규화  (0) 2013.06.06
제 1 정규화(Normal Form)  (1) 2013.06.06
  1. 2017.05.30 15:49 신고

    거꾸로 아닙니까 마지막 줄 ? 제품 주문 테이블에서 제품번호는 제품 테이블의 프라이머리키이고 제품 주문 테이블에서는 외래키가 되는거죠

+ Recent posts