대학교/BE

[데이터베이스] RDBMS 종류와 특성

SWKo 2020. 3. 19. 11:35

0. RDBMS

  • 관계형 DBMS는 열이 속성을 나타내고 테이블의 각 행이 레코드를 나타내는 테이블 형식으로 데이터를 저장한다.
  • RDBMS는 CRUD(Create, Read, Update, Delete) 조작을 허용한다.
  • SQL(Structured Query Language)은 관계형 데이터베이스 관리 시스템(RDMS)에서 데이터를 쿼리, 업데이트 및 삭제하는 데 사용되는 언어이다.
  • SQL은 표준 쿼리 언어이다. SQL언어의 쿼리는 SQL명령 또는 SQL문이라고도 한다.
  • 가장 인기있는 10가지 DBMS는 다음과 같다.(현재 2020.03.19)
  • 출처: https://db-engines.com/en/ranking

 

  • 가장 인기있는 10가지 RDBMS는 다음과 같다.


1. 각 RDBMS 특성

  • Oracle
    • Oracle Corporation에서 개발되었으며 현재 가장 널리 사용되는 RDBMS이다.
    • 사용자 정의 유형, 상속 및 다형성과 같은 객체 지향 기능을 구현하는 RDBMS를 객체 관계형 데이터베이스 관리 시스템(ORDBMS)이라고 한다.
    • Oracle Database는 관계형 모델을 객체 관계형 모델로 확장하여 복잡한 비즈니스 모델을 관계형 데이터베이스에 저장할 수 있다.
    • Oracel Database에서 데이터베이스 스키마는 논리 데이터 구조 또는 스키마 객체의 모음이다. 데이터베이스 사용자는 사용자 이름과 이름이 같은 데이터베이스 스키마를 소유한다.
    • 스키마 객체는 데이터베이스에서 데이터를 직접 참조하는 사용자 생성 구조이다.
    • 데이터베이스는 여러 유형의 스키마 객체를 지원하며 그 중 가장 중요한 것은 테이블과 인덱스이다.

 

  • MySQL
    • MySQL은 오픈 소스이며 무료이고 세계에서 가장 인기있는 DB이다.
    • MySQL의 주요 특징은 다음과 같다.
      • MySQL은 관계형 데이터베이스이다.
      • MySQL소프트웨어는 오픈소스이다.
      • MySQL데이터베이스 서버는 매우 빠르고 안정적이며 확장 가능하며 사용하기 쉽다.
      • MySQL서버는 클라이언트 / 서버 또는 임베디드 시스템에서 작동한다.

 

  • SQL Server
    • Microsoft에서 개발한 SQL Server는 세계에서 가장 널리 사용되는 데이터베이스 중 하나이다.
    • C, C++로 작성되어 있고 SQL Server는 Microsoft Azure Cloud의 일부이다.

 

  • PostgreSQL
    • PostgreSQL은 복잡한 데이터 워크로드를 안전하게 저장하며 SQL 언어를 사용하고 확장하는 오픈 소스 객체 관계형 데이터베이스 시스템이다.
    • PostgreSQL은 아키텍처, 안정서으 데이터 무결성, 강력한 기능 세트, 확장성 및 소프트웨어 뒤의 오픈소스 커뮤니티의 헌신으로 성능과 혁신적인 솔루션을 지속적으로 제공하는 것으로 유명하다.

 

  • IBM DB2
    • IBM DB2는 transaction 및 warehousing workload에 고급 데이터 관리 및 분석 기능을 제공하는 관계형 데이터베이스이다.
    • 고성능, 데이터 가용성 및 안전성을 제공하도록 설계되었으며 Linux, Unix 및 Windows 운영 체제에서 지원된다.
    • DB2 데이터베이스 소프트웨어는 in-memory기술, 고급 관리 및 개발 도구, 스토리지 최적화, 워크로드 관리, 실행 가능한 압축 및 지속적인 데이터 가용성과 같은 고급 기능이 포함되어 있다.
    • Ver11.5에서는 AI기능이 추가되어 데이터 과학 및 AI기술을 채택하여 경쟁 차별화를 가질 수 있다.

 

  • Microsoft Access
    • 원격 또는 중앙 스토리지에서는 일반적으로 액세스가 사용되지 않는다.
    • 로컬 소규모 데이터베이스에 사용된다.

 

  • SQLite
    • SQLite는 작고 빠르며 독립적이다.
    • 신뢰성이 높으며 완전한 기능을 갖춘 SQL 데이터베이스 엔진을 구현하는 C언어 라이브러리이다.
    • SQLite는 모든 휴대폰과 대부분의 컴퓨터에 내장되어 있으며 사람들이 매일 사용하는 수많은 다른 응용 프로그램에 번들로 제공된다.
    • SQLite 파일 형식은 안정적이고 크로스 플랫폼이다.
    • 경우에 따라 SQLite가 direct filesysten I/O보다 빠르다.
    • ANSI-C로 작성되었다.
    • 크로스 플랫폼으로는 Android, *BSD, iOS, Linux, Mac, Solaris, VxWorks, Windows가 기본적으로 지원되며 다른 시스템으로 쉽게 포팅할 수 있다.
    • SQLite를 관리하는데 사용할 수 있는 독립형 CLI클라이언트가 제공된다.

 

  • MariaDB
    • MySQL개발자에 의해 만들어졌으며 오픈 소스를 유지하도록 보장했다.
    • 주요 사용자로는 Wikipedia, WordPress.com, Google이 있다.
    • MariaDB는 은행에서 웹 사이트에 이르기까지 광범위한 응용 프로그램에서 데이터를 구조화 된 정보로 변환한다.
    • MySQL에서 조금의 변화를 가하여 성능을 향상시킬 수 있다.
    • MariaDB는 스토리지 엔진, 플러그인 및 기타 여러 도구로 구성된 풍부한 에코 시스템으로 빠르게 확장 가능하며 강력하기 때문에 다양한 용도로 사용될 수 있다.
    • MariaDB는 오픈 소스 소프트웨어 및 관계형 데이터베이스로 개발되어 데이터 액세스를 위한 SQL 인터페이스를 제공한다.
    • 최신 MariaDB 버전에는 GIS(Geographic Information System)과 JSON(JavaScript Object Notation) 기능도 포함되어 있다.

 

  • Informix
    • IBM Informix는 SQL, NoSQL/JSON, 시계열 및 공간 데이터를 완벽하게 통합 할 수있는 빠르고 유연한 데이터베이스이다.
    • 설치 공간이 작고 자체 관리 기능이 있어 Informix는 임베디드 데이터 관리 솔루션에 적합하다.
    • Informix의 주요 기능은 다음과 같다.
      • Real-time analytics(실시간 분석)
      • Fast, always-on transactions(빠른 상시 거래)
      • Fewer data management hassless(데이터 관리 번거로움 감소)
      • Simplicity(간단함)

  • Azure SQL
    • Azure SQL Database는 최신 안정 버전의 Microsoft SQL Server 데이터베이스 엔진을 기반으로하는 범용 관계형 DBaas(Database as a Service)이다.
    • SQL Database는 인프라를 관리 할 필요없이 선택한 프로그래밍 언어로 데이터 기반 응용 프로그램 및 웹 사이트를 구추가는 데 사용할 수 있는 고성능의 안정적인 클라우드 데이터베이스이다.
    • Azure SQL의 주요 기능은 다음과 같다.
      • Fully managed
        • 안정적인 최신 버전의 SQL Server 데이터베이스 엔진 및 99.99%의 가용성을 가진 패치된 OS에서 항상 실행되는 PaaS(Platform as a Service) 데이터베이스
      • Scalability
        • 응용 프로그램의 성능을 향상시켜야 할 필요에 따라 데이터베이스를 쉽게 확장, 축소 또는 분할 할 수 있다.
      • Elastic pools, Platform as a Service, Advanced Security, Mornitoring and tuning