MongoDB-개요

MongoDB는 고성능, 고 가용성 및 손쉬운 확장 성을 제공하는 크로스 플랫폼 문서 지향 데이터베이스입니다. MongoDB는 수집 및 문서의 개념으로 작동합니다.

데이터 베이스

데이터베이스는 컬렉션을위한 물리적 컨테이너입니다. 각 데이터베이스는 파일 시스템에서 자체 파일 세트를 가져옵니다. 단일 MongoDB 서버에는 일반적으로 여러 데이터베이스가 있습니다.

수집

컬렉션은 MongoDB 문서 그룹입니다. RDBMS 테이블과 동일합니다. 컬렉션은 단일 데이터베이스 내에 있습니다. 컬렉션은 스키마를 적용하지 않습니다. 컬렉션 내의 문서는 다른 필드를 가질 수 있습니다. 일반적으로 컬렉션의 모든 문서는 유사하거나 관련된 목적입니다.

문서

문서는 키-값 쌍의 집합입니다. 문서에는 동적 스키마가 있습니다. 동적 스키마는 동일한 컬렉션의 문서가 동일한 필드 또는 구조 집합을 가질 필요가 없으며 컬렉션 문서의 공통 필드가 다른 유형의 데이터를 보유 할 수 있음을 의미합니다.

다음 표는 RDBMS 용어와 MongoDB의 관계를 보여줍니다.

RDBMS MongoDB
데이터 베이스 데이터 베이스
수집
튜플 / 행 문서
기둥
테이블 조인 포함 된 문서
기본 키 기본 키 (MongoDB 자체에서 제공하는 기본 키 _id)
데이터베이스 서버 및 클라이언트
mysqld / Oracle 몽고
mysql / sqlplus 몽고

샘플 문서

다음 예제는 단순히 쉼표로 구분 된 키 값 쌍인 블로그 사이트의 문서 구조를 보여줍니다.

{
   _id: ObjectId(7df78ad8902c)
   title: 'MongoDB Overview', 
   description: 'MongoDB is no sql database',
   by: 'tutorials point',
   url: 'http://www.tutorialspoint.com',
   tags: ['mongodb', 'database', 'NoSQL'],
   likes: 100, 
   comments: [	
      {
         user:'user1',
         message: 'My first comment',
         dateCreated: new Date(2011,1,20,2,15),
         like: 0 
      },
      {
         user:'user2',
         message: 'My second comments',
         dateCreated: new Date(2011,1,25,7,45),
         like: 5
      }
   ]
}

_id모든 문서의 고유성을 보장하는 12 바이트 16 진수입니다. 문서를 삽입하는 동안 _id를 제공 할 수 있습니다. 제공하지 않으면 MongoDB는 모든 문서에 대해 고유 한 ID를 제공합니다. 현재 타임 스탬프의 경우 12 바이트 처음 4 바이트, 머신 ID의 경우 3 바이트, MongoDB 서버의 프로세스 ID의 경우 2 바이트, 나머지 3 바이트는 단순 증분 VALUE입니다.