목차
1. 데이터베이스 설계과정
2. 데이터베이스 정규화과정
2. 데이터베이스 정규화과정
본문내용
필요 없으나, COMPOSITE PK로 되어진 테이블의 경우는 제2 정규화를 해야 한다. 식별자가 아닌 COLUMN은 식별자 전체 COLUMN에 대해 의존적이어야 하는데 식별자 일부 칼럼에 대해 의존적이라면 그 COLUMN은 분리해서 새로운 개체를 만든다. 예를들면 위의 과목테이블에서 과목명은 과목번호에게 의존적이지만, 전체 Composite PK인 과목명과 교수번호에 전체에 대해 의존적이지 않으므로 분리한다. 즉 과목명이 다르면 과목번호도 다르게 된다. 그러나 과목명과 교수명은 아무런 상관없다. 과목이 같아도 교수는 다른 사람이 같은 과목을 가르칠 수 있거나 하기때문에둘의 연관성이 없다. 중복된 필드값을 제거하고 분리하면 아래와 같은 테이블처럼 만들 수 있다.
<개설과목 테이블>
교수명또한 마찬가지이다. 교수명을 교수번호와는 관련있으나 과목명과는 상관없으므로 새롭게 테이블을 만들면
<교수 테이블>
그리고 교수명과 과목명을 분리한 나머지 남은 항목의 테이블
<강의실관련 테이블>
학생테이블 또한 마찬가리 제2 정규화과정을 거치면 2가지 테이블이 생긴다. 학번의 경우 아래처럼 학번, 과목번호, 교수번호의 COPOSITE PK를 가지므로 분리해야 한다.
<학생개인정보 테이블>
<성적테이블>
현재 학점은 학생테이블의PK(노란색칠한 필드) 전체에 대해 의존적이므로 그대로 둔다.반면 학점 COLUMN은 학번에게만 의존적이므로 분리한다. 그럼 위에처럼 분리된다. 결국 학생테이블이 2개의 테이블로 분리된다.
4) 제3 정규화
식별자가 아닌 컬럼이 식별자가 아닌 칼럼에 대해 의존적이라면 그 칼럼을 분리해서 새로운 개체를 만든다. 위에서 <강의실관련>테이블의 경우 강의실코드와 강의실코드는 서로 의존적이므로 분리할 수 있다.
5) 제4 정규화
제4정규화는 '데이터베이스의 연관관계'를 多:多 관계 ->1:多 관계 바꾸는 과정이다 예를들면 다음과 같이 고객이 과자를 사는 프로세싱과 관련된 데이터베이스를 살펴보면
<회원> 테이블 <제품> 테이블 1행 多행 多행 1행---------------- ---------------회원ID .... 회원명 ... 제품코드... 단가 ...---------------- --------------- P.KP.KCNS 최남선새우깡 1000CJM 최종민양파링 1500PYM 박영민감자깡 800
다음과 같이 회원테이블과 제품테이블은 서로 多:多 관계를 맺고 있음을 알고 있다. 이러한 것을 각기 부모테이블로 하는 하나의 테이블로 구성해보자
<주문> 테이블 ------------------------------ 회원ID 제품코드 주문일자 주문량 ----- ------ F.K F.K CNS 새우깡 SYSDATE 50 CNS 감자깡 SYSDATE 30 CJM 새우깡 SYSDATE 25
위와 같은 하나의 자식테이블을 구성할 수 있는데.이때 새로운 테이블은 PK로 회원ID,제품코드, 주문일자 모두로 가지게 된다. 조금 복잡해 보인다. 이 요소들을 하나의 특성으로 묶어 주문번호라는 COLUMN을 새로 만들어 PK로 지정하면 더 효율적이다. <주문> 테이블 ----------------------------------- 주문번호 회원ID 제품코드 주문일자 주문량 ------ ----- ------ P.K F.K F.K 1 CNS 새우깡 SYSDATE 50 2 CNS 감자깡 SYSDATE 30 3 CJM 새우깡 SYSDATE 25
이렇게되면 회원테이블과 주문테이블관계는 1:多 관계가 되며 제품테이블과 주문테이블의 관계도 1:多 관계가 된다. 즉 새로 만들어진 주문테이블을 매개체로하여 다대다 관계테이블이 1:다 테이블 2개로 나누어지게 만들 수 있다.
<개설과목 테이블>
교수명또한 마찬가지이다. 교수명을 교수번호와는 관련있으나 과목명과는 상관없으므로 새롭게 테이블을 만들면
<교수 테이블>
그리고 교수명과 과목명을 분리한 나머지 남은 항목의 테이블
<강의실관련 테이블>
학생테이블 또한 마찬가리 제2 정규화과정을 거치면 2가지 테이블이 생긴다. 학번의 경우 아래처럼 학번, 과목번호, 교수번호의 COPOSITE PK를 가지므로 분리해야 한다.
<학생개인정보 테이블>
<성적테이블>
현재 학점은 학생테이블의PK(노란색칠한 필드) 전체에 대해 의존적이므로 그대로 둔다.반면 학점 COLUMN은 학번에게만 의존적이므로 분리한다. 그럼 위에처럼 분리된다. 결국 학생테이블이 2개의 테이블로 분리된다.
4) 제3 정규화
식별자가 아닌 컬럼이 식별자가 아닌 칼럼에 대해 의존적이라면 그 칼럼을 분리해서 새로운 개체를 만든다. 위에서 <강의실관련>테이블의 경우 강의실코드와 강의실코드는 서로 의존적이므로 분리할 수 있다.
5) 제4 정규화
제4정규화는 '데이터베이스의 연관관계'를 多:多 관계 ->1:多 관계 바꾸는 과정이다 예를들면 다음과 같이 고객이 과자를 사는 프로세싱과 관련된 데이터베이스를 살펴보면
<회원> 테이블 <제품> 테이블 1행 多행 多행 1행---------------- ---------------회원ID .... 회원명 ... 제품코드... 단가 ...---------------- --------------- P.KP.KCNS 최남선새우깡 1000CJM 최종민양파링 1500PYM 박영민감자깡 800
다음과 같이 회원테이블과 제품테이블은 서로 多:多 관계를 맺고 있음을 알고 있다. 이러한 것을 각기 부모테이블로 하는 하나의 테이블로 구성해보자
<주문> 테이블 ------------------------------ 회원ID 제품코드 주문일자 주문량 ----- ------ F.K F.K CNS 새우깡 SYSDATE 50 CNS 감자깡 SYSDATE 30 CJM 새우깡 SYSDATE 25
위와 같은 하나의 자식테이블을 구성할 수 있는데.이때 새로운 테이블은 PK로 회원ID,제품코드, 주문일자 모두로 가지게 된다. 조금 복잡해 보인다. 이 요소들을 하나의 특성으로 묶어 주문번호라는 COLUMN을 새로 만들어 PK로 지정하면 더 효율적이다. <주문> 테이블 ----------------------------------- 주문번호 회원ID 제품코드 주문일자 주문량 ------ ----- ------ P.K F.K F.K 1 CNS 새우깡 SYSDATE 50 2 CNS 감자깡 SYSDATE 30 3 CJM 새우깡 SYSDATE 25
이렇게되면 회원테이블과 주문테이블관계는 1:多 관계가 되며 제품테이블과 주문테이블의 관계도 1:多 관계가 된다. 즉 새로 만들어진 주문테이블을 매개체로하여 다대다 관계테이블이 1:다 테이블 2개로 나누어지게 만들 수 있다.
추천자료
- 스포츠 리그를 위해 팀들과 게임에 대한 정보를 관리하는 데이터베이스
- 데이터베이스 시스템
- 데이터베이스 DB Design Project ( 삼국지 개념의 국가, 인재, 성의 정보를 관리하는 데이터...
- 데이터베이스 DB를 활용한 마케팅 전략수립과 성공케이스 분석
- 데이터베이스 정규화[예제를 통한 정규화 연습]
- 데이터베이스
- 데이터베이스 관리시스템과 SQL
- 데이터베이스 설계 프로젝트 보고서 인터넷 영화 예매 시스템 구축
- [특허][이중출원][웹데이터베이스][표준화][진보성]특허의 개념, 특허의 분류, 특허의 요건, ...
- 데이터베이스 마케팅(database marketing)의 의의와 목적 및 장단점
- 데이터베이스 설계 최종 보고서 3조
- 데이터베이스 DBMS 언어의 종류 및 특징에 대해서 조사하세요.
- 인터넷 정보검색효율의 측정방법, 인터넷 정보검색효율과 최적화, 인터넷 정보검색효율과 인...
- 데이터베이스 관리와 실습 MS SQL Server 2008(연습문제4장_mssql결과)
소개글