본문 바로가기

데이터베이스/SQL

[DataBase]데이터베이스 시스템-hoyhi

데이터베이스 시스템

컴퓨터를 사용하여 정보를 수집하고 분석하는데 데이터베이스 기술 활용

  • 데이터 : 현실 세계에서 벌어지는 일들을 단순한 방법으로 관찰하고 측정해서 얻은 값
  • 정보 : 그 데이터를 처리해서 얻을 수 있는 결과

데이터베이스(database)의 정의

데이터베이스는 조직체의 응용시스템들이 공유해서 사용하는 운영데이터(operation data)들이 구조적으로 통합된 모임

데이터베이스의 구조는 사용되는 데이터 모델에 의해 결정

 

데이터베이스의 특징

- 데이터베이스는 데이터의 대규모 저장소로서, 여러 부서에 속하는 여러 사용자에 의해 동시 사용

- 모든 데이터가 중복을 최소화하면서 통합

- 데이터베이스는 한 조직체의 운영 데이터뿐만 아니라 그 데이터에 관한 설명까지 포함

- 프로그램과 데이터 간의 독립성 제공

- 효율적으로 접근 가능, 질의 가능

 

데이터베이스 관리 시스템(DBMS, DataBase Management System)

- 데이터베이스를 정의하고 질의어를 지원하며 리포트를 생성하는 등의 작업을 수행하는 소프트웨어

 

데이터베이스 시스템 개요

데이터베이스 스키마

- 전체적인 데이터베이스 구조를 뜻하며 자주 변경되지는 않음

- 데이터베이스의 모든 가능한 상태를 미리 정의

- 내포(intension)라고 부름

 

데이터베이스 상태

- 특정 시점의 데이터베이스의 내용을 의미하며 시간이 지남에 따라 계속해서 바뀜

- 외연(extension)이라고 부름

 

ex)

데이터베이스 스키마

DEPARTMENT (DEPTNO, DEPTNAME, FLOOR)

EMPLOYEE (EMPNO, EMPNAME, TITLE, DNO, SALARY)

 

데이터베이스 상태

DEPARTMENT

DEPTNO DEPTNAME FLOOR
1 영업 8
2 기획 10
3 개발 9

 

EMPLOYEE

EMPNO EMPNAME TITLE DNO SALARY
2106 김창섭 대리 2 2000000
3426 박영권 과장 3 2500000
3011 이수민 부장 1 3000000
1003 조민희 대리 1 2000000
3427 최종철 사원 3 1500000

 

데이터베이스 시스템 (DBS: DataBase System)

DBS

 

데이터베이스

- 조직체의 응용 시스템들이 공유해서 사용하는 운영 데이터들이 구조적으로 통합된 모임

- 시스템 카탈로그(또는 데이터 사전)와 저장된 데이터베이스로 구분 가능

- 시스템 카탈로그는 저장된 데이터베이스의 스키마 정보를 유지

 

DBMS

- 사용자가 새로운 데이터 베이스를 생성하고, 데이터베이스의 구조를 명시할 수 있게 하고, 사용자가 데이터를

  효율적으로 질의하고 수정할 수 있도록 하며, 시스템의 고장이나 권한이 없는 사용자로부터 데이터 보호

  동시에 여러 사용자가 데이터베이스를 접근하는 것을 제어하는 소프트웨어 패키지

- 데이터베이스 언어라고 하는 특별한 프로그래밍 언어를 한 개 이상 제공

- SQL은 여러 DBMS에서 제공되는 사실상의 표준 데이터베이스 언어

컴퓨터 시스템에서 DBMS 위치

 

사용자

- 데이터베이스 사용자는 여러 부류로 나눌 수 있음

 

하드웨어

- 데이터베이스는 디스크와 같은 보조 기억 장치에 저장되며, DBMS에서 원하는 정보를 찾기 위해

  디스크의 블록들을 주기억 장치로 읽어들여야 하며, 계산이나 비교 연산들을 수행하기 위해 CPU 사용

- DBMS 자체도 주기억 장치에 적재되어 실행되어야 함

 

데이터베이스 시스템의 요구사항

- 데이터 독립성

- 효율적인 데이터 접근

- 데이터에 대한 동시 접근

- 백업과 회복

- 중복을 줄이거나 제어하며 일관성 유지

- 데이터 무결성

- 데이터 보안

- 쉬운 질의어

- 다양한 사용자 인터페이스

 

화일 시스템 vs DBMS

화일 시스템을 사용한 기존의 데이터 관리

- 화일 시스템은 DBMS가 등장하지 않았을 때인 1960년대~ 사용

- 화일의 기본적인 구성요소는 순차적인 레코드들

- 한 레코드는 연관된 필드들의 모임

- 화일을 접근하는 방식이 응용 프로그램 내에 상세하게 표현 -> 데이터에 대한 응용 프로그램 의존도 높음

 

화일 시스템의 단점

- 데이터가 많은 화일에 중복 저장

- 다수 사용자들을 위한 동시성 제어 제공 X

- 검색하려는 데이터를 쉽게 명시하는 질의어 제공 X

- 보안 조치가 미흡

- 회복 기능 X

- 프로그램-데이터 독립성 X -> 유지보수 비용 많이 소요

- 데이터 모델링 개념 부족

- 무결성 유지의 어려움

- 화일 검색 또는 갱신하는 절차가 상대적으로 복잡해 프로그래머의 생산성이 낮음

 

DBMS를 사용한 데이터베이스 관리

- 여러 사용자와 응용 프로그램들이 데이터베이스 공유

- 사용자의 질의를 빠르게 수행할 수 있는 인덱스 등의 접근 경로를 DBMS가 자동으로 선택 수행

- 권한이 없는 사용자로부터 데이터베이스 보호

- 여러 사용자에 적합한 다양한 인터페이스 제공

- 데이터 간의 복잡한 관계를 표현, 무결성 제약조건을 DBMS가 자동적으로 유지

- 시스템이 고장 나면 데이터베이스를 고장 전의 일관된 상태로 회복시킴

- 프로그램에 영향을 주지 않으면서 데이터베이스 구조를 변경할 수 있음

  프로그램-데이터 독립성(program-data independence)

 

DBMS의 장점

- 중복성과 불일치가 감소됨

- 프로그램-데이터 독립성 향상

- 시스템을 개발하고 유지하는 비용이 감소됨

- 보안이 향상됨 

- 무결성이 향상됨

- 다양한 유형의 고장으로부터 데이터베이스를 회복할 수 있음 

- 데이터베이스의 공유와 동시 접근이 가능함

 

DBMS 선정 시 고려사항 

기술적 요인

- DBMS에 사용되고 있는 데이터 모델, DBMS가 지원하는 사용자 인터페이스, 프로그래밍 언어, 응용 개발 도구

  저장 구조, 성능, 접근 방법 등

경제적 요인

- 소프트웨어와 하드웨어 구입 비용, 유지 보수 비용, 직원들의 교육 지원 등

 

DBMS 발전 과정

데이터 모델

- 데이터베이스의 구조를 기술하는데 사용되는 개념들의 집합인 구조(데이터 타입과 관계)

  이 구조 위에서 동작하는 연산자들, 무결성 제약조건들

- 사용자에게 내부 저장 방식의 세세한 사항은 숨기면서 데이터에 대한 직관적인 뷰를 제공하는 동시에 이들 간의 사상    을 제공

 

데이터 모델의 분류

고수준 또는 개념적 데이터 모델(conceptual data model)

- 사람이 인식하는 것과 유사하게 데이터베이스의 전체적인 논리적 구조를 명시

- 예: 엔티티-관계(ER: Entity-Relationship) 데이터 모델과 객체 지향 데이터 모델

 

표현(구현) 데이터 모델(representation(implementation) data model, logical data model)

- 최종 사용자가 이해하는 개념이면서 컴퓨터 내에서 데이터가 조직되는 방식과 멀리 떨어져 있지는 않음

- 예: 계층 데이터 모델(hierarchical data model), 네트워크 데이터 모델(network data model), 관계 데이터 모델(relational data model)

 

저수준 또는 물리적인 데이터 모델(physical data model)

- 데이터베이스에 데이터가 어떻게 저장되는가를 기술

- 예: Unifying, ISAM, VSAM 등

 

관계 DBMS

- 1970년에 E.F. Codd가 IBM 연구소에서 관계 데이터 모델을 제안

- 미국 IBM 연구소에서 진행된 System R과 캘리포니아 버클리대에서 진행된 Ingres 프로젝트

- 장점 : 모델이 간단하여 이해하기 쉬움, 사용자는 자신이 원하는 것(what)만 명시하고, 데이터가 어디에 있는지, 어떻게 접근해야 하는지는 DBMS가 결정

- 예: 오라클, MS SQL Server, DB2 등

 

객체 지향 DBMS

- 1980년대 후반 들어 새로운 데이터 모델인 객체 지향 데이터 모델이 등장

- 객체 지향 프로그래밍 패러다임을 기반으로 하는 데이터 모델

- 장점 : 데이터와 프로그램을 그룹화하고, 복잡한 객체들을 이해하기 쉬우며, 유지와 변경이 용이함

- 예 : ONTOS, OpenODB, GemStone, ObjectStore, Versant, O2 등

 

객체 관계 DBMS

- 1990년대 후반에 관계 DBMS에 객체 지향 개념을 통합한 객체 관계 데이터 모델이 제안됨

- 예: 오라클, Informix Universal Server 등

 

새로운 데이터베이스 응용

- CAD 데이터베이스, 소프트웨어 공학 데이터베이스(재사용이 가능한 소프 트웨어들의 라이브러리), 게놈 데이터베이스, 데이터 웨어하우스, 데이터 마이닝, OLAP, 멀티미디어 데이터베이스, 웹 데이터베이스, XML 데이터베 이스, 공간 데이터베이스, 스트림 데이터베이스, 이동 데이터베이스 , 메인 메모리 데이터베이스 등

 

현대의 관계 DBMS의 기능

 

DBMS 언어

데이터 정의어(DDL : Data Definition Language)

- 사용자는 데이터 정의어를 사용하여 데이터베이스 스키마 정의

- 데이터 정의어로 명시된 문장이 입력되면 DBMS는 사용자가 정의한 스키마에 대한 명세를

  시스템 카탈로그 또는 데이터 사전에 저장

- 데이터 정의어의 기본적인 기능

ex)

데이터 모델에서 지원하는 데이터 구조를 생성

예, SQL에서 CREATE TABLE

 

데이터 구조의 변경

예, SQL에서 ALTER TABLE

 

데이터 구조의 삭제

예, SQL에서 DROP TABLE

 

데이터 접근을 위해 특정 애트리뷰트 위에 인덱스를 정의

예, SQL에서 CREATE INDEX

 

데이터 조작어(DML: Data Manipulation Language)

- 사용자는 데이터 조작어를 사용하여 데이터베이스 내의 원하는 데이터를 검색하고, 수정하고, 삽입하고, 삭제

- 절차적 언어(procedural language)와 비절차적 언어(non-procedural language)

- 관계 DBMS에서 사용되는 SQL은 대표적인 비절차적 언어

- 대부분의 데이터 조작어는 SUM, COUNT, AVG와 같은 내장 함수들을 갖고 있음

- 데이터 조작어는 단말기에서 대화식으로 입력되어 수행되거나 C, 코볼 등 의 고급 프로그래밍 언어로 작성된 프로그램

  에 내포되어 사용됨

- 데이터 조작어(DML: Data Manipulation Language)의 기본적인 기능

ex)

데이터의 검색

예, SQL에서 SELECT

 

데이터의 수정

예, SQL에서 UPDATE

 

데이터의 삭제

예, SQL에서 DELETE

 

데이터의 삽입

예, SQL에서 INSERT

DDL & DML

 

데이터 제어어(DCL: Data Control Language)

- 사용자는 데이터 제어어를 사용하여 데이터베이스 트랜잭션을 명시하고 권한 부여 및 취소

 

DBMS 사용자

DBMS 사용자들

 

데이터베이스 관리자(DBA, DataBase Administrator)

- 데이터베이스 관리자는 조직의 여러 부분의 상이한 요구를 만족시키기 위해서 일관성 있는

  데이터베이스 스키마를 생성하고 유지하는 사람(팀)

 

데이터베이스 관리자의 역할

- 데이터베이스 스키마의 생성과 변경

- 무결성 제약조건을 명시

- 사용자의 권한을 허용하거나 취소하고, 사용자의 역할을 관리

- 저장 구조와 접근 방법 정의

- 백업과 회복

- 표준화 시행

 

응용 프로그래머

- 데이터베이스 위에서 특정 응용(고객 관리, 인사관리 등)이나 인터페이스를 구현하는 사람

- 고급 프로그래밍 언어인 C, 코볼 등으로 응용 프로그램을 개발하면서 데이터베이스를 접근하는 부분은

  내포된 데이터 조작어 사용

- 이들이 작성한 프로그램은 최종 사용자들이 반복해서 수행하므로 기작성 트랜잭션이라 부름

 

최종 사용자(end user)

- 질의하거나 갱신하거나 보고서 생성을 위해 데이터베이스 사용

 

데이터베이스 설계자(database designer)

- ERWin 등의 CASE 도구들을 이용해서 데이터베이스 설계를 담당

- 데이터베이스의 일관성 유지를 위해 정규화 수행

 

오퍼레이터

- DBMS가 운영되고 있는 컴퓨터 시스템과 전산실 관리

 

ANSI/SPARC 아키텍처와 데이터 독립성

ANSI/SPARC 아키텍처

- 현재의 대부분의 사용 DBMS 구현에서 사용되는 일반적인 아키텍처는 1978년에 제안된 ANSI/SPARC 아키텍처

- ANSI/SPARC 아키텍처의 3단계는 물리적, 개념적, 외부 단계로 이루어짐

외부단계(external level) : 각 사용자의 뷰(view)

개념단계(conceptual level) : 조직체의 정보 모델(스키마, 전체 데이터베이스의 논리적인 구조)

내부단계(internal level) : 물리적인 데이터 구조

ANSI / SPARC 3단계 아키텍처
관계 데이터 모델에서 3단계 아키텍처의 예

스키마 간의 사상

- DBMS는 세 가지 유형의 스키마 간의 사상을 책임짐

- 외부/개념 사상(external/conceptual mapping) : 외부 단계의 뷰를 사용해서 입력된 사용자의 질의를 개념 단계의 스키마를 사용 한 질의로 변환

- 개념/내부 사상(conceptual/internal mapping) : 이를 다시 내부 단계의 스키마로 변환하여 디스크의 데이터베이스를 접근

 

데이터 독립성

- 상위 단계의 스키마 정의에 영향을 주지 않으면서 어떤 단계의 스키마 정의 를 변경할 수 있음을 의미

> 논리적인 데이터 독립성(logical data independence)

> 물리적인 데이터 독립성(physical data independence)

논리적 데이터 독립성과 물리적 데이터 독립성

 

논리적 데이터 독립성

- 개념 스키마의 변화로부터 외부 스키마가 영향을 받지 않음을 의미

- 기존의 외부 스키마에 영향을 미치지 않고, 응용 프로그램을 다시 작성할 필요 없이 개념 스키마에 대한 변화가 가능해야 함

 

물리적 데이터 독립성

- 내부 스키마의 변화가 개념적 스키마에 영향을 미치지 않으며, 따라서 외부 스키마(또는 응용 프로그램)에도 영향을 미치지 않음을 의미

- 내부 스키마의 변화의 예: 화일의 저장 구조를 바꾸거나 인덱스를 생성 및 삭제

 

데이터베이스 시스템 아키텍처

데이터베이스 시스템의 간단한 아키텍처

데이터 정의어 컴파일러(DDL compiler) 모듈

- 데이터 정의어를 사용하여 테이블 생성을 요청하면 테이블을 파일 형태로 데이터베이스에 만들고, 이 테이블에 대한 명세를 시스템 카탈로그에 저장

 

질의 처리기(query processor) 모듈

- 데이터 조작어를 수행하는 최적의 방법을 찾는 모듈을 통해서 기계어 코드로 번역

 

런타임 데이터베이스 관리기(run-time database manager, storage manager) 모듈

- 디스크에 저장된 데이터베이스를 접근

 

트랜잭션 관리(transaction management) 모듈

- 동시성 제어(concurrency control) 모듈

- 회복(recovery) 모듈

 

중앙 집중식 데이터베이스 시스템(centralized database system)

- 데이터베이스 시스템이 하나의 컴퓨터 시스템에서 운영됨

중앙 집중식 데이터베이스 시스템

 

 

분산 데이터베이스 시스템(distributed database system)

- 네트워크로 연결된 여러 사이트에 데이터베이스 자체가 분산되어 있으며, 데이터 베이스 시스템도 여러 컴퓨터 시스템에서 운영됨

- 사용자는 다른 사이트에 저장된 데이터베이스도 접근할 수 있음

분산 데이터베이스 시스템

 

클라이언트-서버 데이터베이스 시스템(client-server database system)

- PC 또는 워크스테이션처럼 자체 컴퓨팅 능력을 가진 클라이언트를 통해 데이터베이스 서버를 접근

- 데이터베이스가 하나의 데이터베이스 서버에 저장되어 있음

- 데이터베이스 시스템의 기능이 서버와 클라이언트에 분산됨

- 서버는 데이터베이스를 저장하고 DBMS를 운영하면서 여러 클라이언트에 서 온 질의를 최적화하고, 권한 검사를 수행하고, 동시성 제어와 회복 기능 을 수행하고, 데이터베이스의 무결성을 유지하고, 데이터베이스 접근을 관리

- 클라이언트는 사용자 인터페이스를 관리하고 응용들을 수행

클라이언트-서버 데이터베이스 시스템

 

2층 모델(2-tier model)

- 클라이언트와 데이터베이스 서버가 직접 연결

 

3층 모델(3-tier model)

- 클라이언트와 데이터베이스 서버 사이에 응용 서버가 추가