데이터 베이스 구조와 성능

2023. 6. 8. 10:59· Computer Science/데이터베이스
목차
  1. 슈퍼타입 / 서브타입 모델
  2.  
  3. 슈퍼/서브 타입 모델의 물리 데이터 모델변환 유형 3가지
  4. 슈퍼/서브타입 모델 변환 방법
  5. 슈퍼/서브타입 데이터 모델 변환 타입 비교
  6. PK/FK 칼럼 순서와 기능

슈퍼타입 / 서브타입 모델

  • 업무를 구성하는 데이터의 특징을 분석하여 공통점/ 차이점을 고려하여 효과적으로 표현할 수 있음
  • 공통의 부분을 슈퍼타입 엔티티로 모델링하고 공통으로부터 상속받아 다른 엔티티와 차이가 있는 속성에 대해서는 별도의 서브타입 엔티티로 구분
  • 업무의 모습을 정확하게 표현하면서 물리적인 데이터 모델로 변환을 할 때 선택의 폭을 넓힐 수 있는 장점이 있음
  • 예시: 고객(슈퍼), 개인고객(서브), 법인고객(서브)

 

슈퍼/서브 타입 모델의 물리 데이터 모델변환 유형 3가지

  • 슈퍼타입
  • 서브타입
  • 개별타입

 

 

슈퍼/서브타입 모델 변환 방법

슈퍼/서브타입 데이터 모델의 변환의 중요성

  • 트랜잭션은 항상 슈퍼타입 기준으로 처리하는데 테이블은 개별타입으로 유지되어 UNION 연산에 의해 성능이 저하될 수 있다. (슈퍼타입기준으로 테이블을 구성하는 것이 유리한 경우이다.)
  • 트랜잭션은 항상 서브타입을 기준으로 처리하는데 개별타입 혹은 슈퍼타입으로 되어 있는 경우 성능이 저하되는 경우가 있다. (서브타입기준으로 테이블을 구성하는 것이 유리한 경우이다.)
  • 트랜잭션은 항상 개별타입 기준으로 처리하는데 테이블은 슈퍼타입으로 되어 있어 불필요하게 많은 양의 데이터가 집약되어 있어 성능이 저하되는 경우가 있다.(개별타입으로 테이블을 구성하는 것이 유리한 경우이다.)

 

 

  • 전체를 하나로 묶어 트랜잭션이 발생할 때는 하나의 테이블로 구성
    • 대리인 10만건, 매수인 500만건, 이해관계인 500만건의 데이터가 존재한다고 하더라도 데이터를 처리할 때 대리인, 매수인, 이해관계인을 항상 통합하여 처리한다고 하면 테이블을 개별로 분리하면 불필요한 조인을 유발하거나 불필요한 UNION ALL과 같은 SQL구문이 작성되어 성능이 저하된다.

슈퍼/서브타입 데이터 모델 변환 타입 비교

 

 

PK/FK 칼럼 순서와 기능

개요

  • 데이터에 발생되는 트랜잭션 조회 패턴에 따라 PK/FK 칼럼의 순서를 조정해야 함
  • 성능저하 현상이 많은 부분이 PK가 여러개의 속성으로 구성된 복합식별자일 때 PK순서에 대해 별로 고려하지 않고 데이터 모델링을 한 경우에 해당
  • 물리적인 데이터 모델링 단계에서는 스스로 생성된 PK순서 이외에 다른 엔티티로부터 상속받아 발생되는 PK순서까지 항상 주의하여 표시

PK가 복합키일 경우 컬럼순서가 성응에 영향을 미치는 이유

  • 인덱스 선두 칼럼에 대한 조건 들어와야 한다. (가능한한'='조건으로)
  • 인덱스 선두 칼럼에 대한 조건이 들어오지 않을 경우 인덱스 전체를 읽거나 테이블 전체를 읽게 됨

  • 가급적 sql문에서 =인 조건컬럼이 위로 오는 것이 검색시 유리하다

'Computer Science > 데이터베이스' 카테고리의 다른 글

관계형 데이터베이스(Relational Database)  (1) 2023.06.09
분산 데이터베이스와 성능  (0) 2023.06.08
대량 데이터에 따른 성능  (0) 2023.06.08
반정규화와 성능  (0) 2023.06.08
정규화와 성능  (0) 2023.06.08
  1. 슈퍼타입 / 서브타입 모델
  2.  
  3. 슈퍼/서브 타입 모델의 물리 데이터 모델변환 유형 3가지
  4. 슈퍼/서브타입 모델 변환 방법
  5. 슈퍼/서브타입 데이터 모델 변환 타입 비교
  6. PK/FK 칼럼 순서와 기능
'Computer Science/데이터베이스' 카테고리의 다른 글
  • 관계형 데이터베이스(Relational Database)
  • 분산 데이터베이스와 성능
  • 대량 데이터에 따른 성능
  • 반정규화와 성능
윤재에요
윤재에요
yunzae.log윤재에요 님의 블로그입니다.
윤재에요
yunzae.log
윤재에요
전체
오늘
어제
  • 분류 전체보기 (438)
    • Computer Science (115)
      • 데이터베이스 (50)
      • 네트워크 (18)
      • 소프트웨어 공학 (1)
      • 알고리즘 (10)
      • 자료구조 (9)
      • 컴퓨터구조 (0)
      • 운영체제 (0)
      • 데이터 통신 (16)
      • 프로그래밍언어론 (11)
    • Project (20)
      • 후크(Flutter) (1)
      • BDSR로그북(App,BackEnd) (2)
      • 나만의 주점(STM32,Arduino,androi.. (9)
      • 공다(App,BackEnd) (2)
      • 카카오쇼핑 클론코딩 (4)
      • 암호화폐자동매매 (2)
    • Problem Solving (208)
      • 자바 문법 (20)
      • 파이썬 문법,함수 (6)
      • 그리디 (5)
      • 구현 (43)
      • DFS (3)
      • BFS (17)
      • 정렬 (15)
      • 이진 탐색 (16)
      • 다이나믹 프로그래밍 (6)
      • 최단 경로 (5)
      • 그래프 (1)
      • 자료구조 (5)
      • 투포인터 (15)
      • SQL (44)
      • 구간합 (7)
    • I leaned (78)
      • 스프링,스프링부트 (31)
      • Git (6)
      • JAVA (5)
      • Etc (30)
    • 취업 (15)
      • PT면접 (6)
      • 기술면접 (9)
      • 인성면접 (0)
    • log (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록
  • 글쓰기

공지사항

인기 글

태그

  • DP
  • 재시도
  • 플로이드 워셜
  • 이것이 코딩테스트다.
  • UML
  • 최단 거리
  • 이것이코딩테스트다
  • 참조 무결성
  • 부품찾기
  • 다익스트라
  • 다이나믹프로그래밍
  • Relationship model
  • 데이터베이스
  • 이것이 코딩테스트다
  • 계수정렬
  • 최단거리
  • 효율적인화폐구성
  • 그리디
  • 교환정렬
  • 파이썬
  • 다이어그램
  • 힙큐
  • 다이나믹
  • 카카오테크캠퍼스
  • 먀
  • 제약 사항
  • 기수정렬
  • weak entity
  • 개미전사
  • E-R Model

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
윤재에요
데이터 베이스 구조와 성능
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.