일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- JavaScript
- Intent
- Selector
- #청주주님의교회
- CSS
- 글쓰기
- 웹개발
- 에디터
- 안드로이드
- 프로그래밍
- 안드로이드 AVD
- 영성
- jQuery
- TinyMCE
- 주님의교회
- 아이콘
- 게시판
- 회원가입
- androidstudio
- Java
- 청주
- 인텐트
- Android
- Resources
- Spring
- Activity
- 제이쿼리
- 자바
- 생명주기
- java 8
- Today
- Total
공부하는 블로그
DB정규화 본문
DB 정규화
자료의 손실이나 불필요한 정보의 도입없이 데이터의 일관성, 데이터 중복을 최소화하고 최대의 데이터 안정성을 확보를 위한 안정적 자료 구조로 변환하기 위해서 하나의 테이블을 둘 이상으로 분리하는 작업
목적 ?
자료 저장에 필요한 저장 공간을 최소화
자료의 삽입, 갱신 및 삭제에 따른 이상 현상 제거(데이타 무결성 유지)
자료 구조의 안정성 최대화
단점 -> 테이블이 많이 질수록 join이 더 많이 일어난다(다른 테이블 접근 경우)
제 1정규화(1NF)
★ 반복되는 그룹속성이 존재할 경우 그 그룹을 분리하여 새로운 엔티티타입을 추가한 후 기존의 실체와 1:N의 관계를 형성해 준다.
예제1
컴퓨터 학원에서 수강생에 대한 자격증 보유 사항 테이블을 만든다고 가정해보자
[자격증 보유 사항 테이블] 기본키; 학생번호
학생번호 | 이름 | 주소 | 핸드폰번호 | 자격증 | 자격증번호 | 취득일 |
제1 정규화를 하지 않고 테이블 사용시 문제점
쓸데없는 데이터베이스 공간의 낭비가 발생한다. 또한 주소나 핸드폰번호의 변경이 있을 경우 4개의 레코드를 모두 변경해야 한다.
만약 학생번호 1인 김개똥이라는 친구가 자격증을 4개를 가지고 있다면 김개똥에 대한 정보, 즉 회원번호, 이름, 주소, 핸드폰번호등의 정보가 중복해서 저장되어진다. 아래 표와 같이
학생번호 | 이름 | 주소 | 핸드폰번호 | 자격증 | 자격증번호 | 취득일 |
1 | 김개똥 | 하와이 | 019-999-999 | 정보처리 | 12345 | 백수 |
1 | 김개똥 | 하와이 | 019-999-999 | 워드1급 | 23456 | 고2 |
1 | 김개똥 | 하와이 | 019-999-999 | 오라클 | 34512 | 고2 |
1 | 김개똥 | 하와이 | 019-999-999 | MCSE | 12341 | 고3 |
☆ 해결 방법 -> 1NF : 반복되는 그룹 속성 분리
중복되는 속성을 4 -> 1으로 줄임
참고] 자격증 보유테이블에서 학생번호는 FK이면서 동시에 PK<식별자 관계>
예제2
마찬가지로 컴퓨터 학원에서 교육과정에 대한 테이블을 만든다고 가정해 보자
[교육과정에 대한 테이블] 기본키 : 과정코드
과정코드 | 과정명 | 교육기간 | 강의시간 | 수강료 | 교재1 | 교재2 | 교재3 | 교재4 |
제1 정규화를 하지 않고 테이블 사용시 문제점
column명만을 보더라도 문제점이 보인다. 어떤 교육과정에서 교재4권 모두 사용해 모든 column을 사용 할수도 있지만 또 다른 교육과정에서는 교재가 1권만이 필요 하다면 나머지 교재2, 교재3, 교재4의 데이터 저장공간의 낭비가 이루어진다.
☆ 해결 방법 -> 1NF : 반복되는 그룹 속성 분리
교재 column처럼 반복되는 속성을 갖는 column의 경우에는 테이블에 null값이 입력되는 수가 있으므로 이러한 경우의 수를 제거하기 위해 테이블을 따라 분리해서 기존의 테이블과 1:N의 관계로 형성해야함. 이해가 되지않는다면 values을 넣어서 보면 된다.
제 2정규화(2NF)
★ 기본키 2개 이상으로 구성되는 테이블에서 일부 속성에 대해서만 부분적으로 함수 종속적인 것을 분리 즉, 부분함수 종속성을 제거
다시 말해 기본키가 하나 인 경우 제 2정규화를 하지 않고 Pass!!
예제 1
컴퓨터 학원에서 수강생에 대한 교육과정별 평가에 대한 테이블 만들었다고 가정해보자
[학생 성적테이블] 기본키 : 학번, 과정코드
학번 | 과정코드 | 평가 | 과정명 | 기간 |
제2 정규화를 하지 않고 테이블 사용시 문제점
과정명 하나만 수정해도 모두 바꾸어야 주어야 한다. 즉, 중복된다. (1NF와 동일)
->무결성 유지 힘듬
column명 만을 보면 어찌해야 되는지 알 수 없다. 가볍게 data를 삽입해보자
학번 | 과정코드 | 평가 | 과정명 | 기간 |
200 | A01 | A | JAVA | 1개월 |
200 | A02 | A | DB | 2개월 |
201 | B01 | B | ASP | 2개월 |
202 | A01 | A | JAVA | 1개월 |
203 | B01 | C | ASP | 2개월 |
- 모든 data는 [학번,과정코드]의 키로 unique 해진다(중복된 data X). 즉 1NF Pass
- 복합키[학번,과정코드]에 ‘평가’는 완전 종속이 된다.
- 복합키 중 하나인 '과정코드'에 ‘과정명’과 ‘기간’이 부분 종속 되어진다.
그림으로 보자면 ↓
☆ 해결 방법 -> 2NF : 부분적 종속 제거
부분적 종속을 제거해준다. 즉 과정코드를 기본키로해서 테이블을 분리 해준다.
제 3정규화(2NF)
★ Primary key가 아닌 일반 column으로 종속되어지는 column 분리. A -> B, B -> C 그러므로 논리적으로 A -> C. 즉, 이행적 종속 관계를 분리한다.
에제 1
제 1정규화 할때 쓴 테이블 가져와 보자. 제 1정규화를 하고 기본키가 하나 이기때문에 제 2정규화 과정은 pass
[교육과정테이블] 기본키 : 학번(FK)
학번 | 자격증 | 자격증번호 |
1 | 정보처리 | 12345 |
1 | 워드1 | 23456 |
2 | 정보처리 | 12345 |
3 | 컴활1 | 87452 |
4 | SCJP | 44444 |
제3 정규화를 하지 않고 테이블 사용시 문제점
- 새로운 자격증이 추가 되어 삽입하려고 할때 이 자격증을 취득하고 있는 사람이 존재 하지 않더라도 가상으로 취득 한 것처럼 해야만 삽입이 가능하다
- 학번이 2인 사람이 학원을 그만 두게 되어 내용을 삭제하려고 할때 유지되어야 할 데이터까지 삭제됨(정보처리 12345)
- 특정 학생이 자격증을 취득하게 되면 그 자격증에 의하여 자격증 번호가 결정됨. 즉 기본키가 아닌 속성인 자격증에 의해서 자격증번호가 결정되게 되며 학번으로 자격증번호를 검색 할 수 있음(이를 이행적 함수 종속성)
학번 -> 자격증, 자격증 -> 자격증번호, ∴ 학번 -> 자격증번호
그림으로 보자면 ↓
☆ 해결 방법 -> 3NF : 이행적 종속 제거
- http://blog.daum.net/sweetheev/4171747 블로그 보면서 공부한내용
기억해야 할 내용))
정규화
무조건 테이블을 나누는 작업이 아니고 각 단계에서 얻고자 하는 바를 알면 쉽게 해결될 수 있다.
제1 정규화 -> 중복되는 data 분리
- 저장공간을 최소화하기 위해서
- N:N 관계를 1:N으로 바꾸기 위해서
- 수정시 모든 레코드의 data 변경
제 2 정규화(복합키 인 경우만 보면 된다.) -> 부분 종속 분리
- 원하는 바는 제 1정규화와 동일
제 3 정규화 -> 이행적 종속 관계 분리
- 삽입이상 제거
- 삭제이상 제거
'Develop > DB' 카테고리의 다른 글
SQL injection (0) | 2018.01.26 |
---|---|
Database에서 Index란? (0) | 2018.01.24 |
(ORACLE) DELETE (데이터삭제) (0) | 2017.09.21 |
(ORACLE) UPDATE (데이터수정) (0) | 2017.09.21 |
(ORACLE) INSERT (데이터삽입) (0) | 2017.09.21 |