IT/SQL

MySQL[1] - DBMS

올빼밋. 2022. 5. 24. 20:18
728x90
목차
1. DBMS의 기초
2. RDBMS(관계형 데이터베이스 시스템)

 

1. DBMS의 기초

DBMS(Data Base Management System) : 데이터베이스(DB)를 관리하는(Management) 시스템(Systme) - DB: 테이블들이 보여 이루는 데이터 단위

  • 데이터를 저장하고 유지보수(수정, 삭제, 추가)하고 이를 검색하는 시스템 - CRUD(Create, Retrieve, Update, Delete)
  • 대량의 데이터를 처리하는 시스템
  • 다양한 자료구조와 검색 구조 사용해 ‘빠른’ 검색 가능 > 검색에 최적화(인덱스)
  • 대부분의 시스템은 검색 >>> 업데이트의 빈도수가 맣음
  • 검색에 최적화(쓰기에 최적화된 시스템은 NoSQL계열)

 

[정렬]

  • 빠른 검색을 위해서는 데이터가 반드시 정렬되어있어야 함
  • 정렬되어 있지 않다면, 평균적으로 전체 데이터의 절반 필요(최선: 1, 최악: N, 평균: N/2)
  • 정렬되면 있을 경우 데이터를 빠른 시간안에 찾을 수 있음 O(NlogN)-O(N^2)
  • 퀵정렬/힙정렬 계열이 주로 사용됨

 

[인덱스]

  • 정렬 데이터에서 빠른 데이터 검색을 위해 사용하는 개념
  • DB에서 인덱스는 바이너리와 B-Tree가 있음
  • 데이터 추가/수정/삭제할 때마다 정렬/인덱스 업데이트가 일어남

 

[Binary Search]

  • 한 가운데 값을 확인

 

[B-Tree]

  • 비교를 한번에 하나만 하는 이진 검색과 달리, 비트리는 두개의 값을 비교함
  • 이진 검색과 유사하지만 한 번에 비교를 2번 (a, b : a < b)
  • B-Tree가 Binary Search 계열보다 빠름
  • 데이터가 추가/삭제/변경 될때마다 a, b 값을 업데이트

 

[DBMS의 종류]

  • 계층형 데이터베이스
  • 네트워크형 데이터베이스
  • 관계형 데이터베이스(RDBMS) -> 주류
  • 객체지향 데이터베이스
  • 객체관계형 데이터베이스(ORDBMS)
  • NoSQL(Not Only SQL) <- 최근에는 검색보다 업데이트에 최적화된 DB가 있음

 

2. RDMBS(관계형 데이터베이스)

[RDBMS]

  • 데이터를 테이블 형태로 저장하고 관리하는 형태
  • 테이블(Table based) 기반의 DBMS
  • 모델링 E-R(Entity Relationship) 모델을 사용
  • 테이블을 엔티티(기본)와 릴레이션십(유도) 테이블로 구분하는 방식
  • 데티터를 테이블 단위로 관리 -> 하나의 테이블은 여러개의 컬럼으로 구성
  • 테이블끼리의 중복 정보는 최소화시킴
  • 사용방식

 

[RDBMS 기본용어]

  • 스키마(Schema) : DB, 테이블 정의 내역
  • SQL 쿼리(SQL Query)
  • 기본키(Primary Key: PK)
  • 외래키(Foreign Key: FK)
  • 테이블(Table)
  • 컬럼(Column)
  • 레코드(Record)
  • 도메인값(Domain Value)

 

728x90