Docs Menu
Docs Home
/
MongoDB 매뉴얼
/

MongoDB의 데이터베이스 및 컬렉션

이 페이지의 내용

  • 개요
  • Databases
  • 컬렉션

MongoDB는 데이터 기록을 개의문서 (특히 BSON 문서)로 저장하며, 이는 컬렉션에 함께 수집 됩니다. 데이터베이스 는 하나 이상의 문서 컬렉션을 저장합니다.

Atlas UI, 또는 MongoDB Compass에서 Atlas cluster의mongosh 데이터베이스컬렉션 을 관리할 수 있습니다. 이 페이지에서는 Atlas UI에서 Atlas cluster의 데이터베이스 및 컬렉션을 관리하는 방법을 설명합니다. 자체 관리형 배포서버의 mongosh 경우 또는 MongoDB Compass를 사용하여 데이터베이스 및 컬렉션을 관리할 수 있습니다.

데이터베이스 및 컬렉션을 관리하는 데 사용할 클라이언트를 선택합니다.

MongoDB Atlas는 선택한 클라우드 제공자에서 데이터베이스를 간편하게 배포하고 관리할 수 있는 멀티 클라우드 데이터베이스 서비스입니다.

MongoDB Shell mongosh 는 MongoDB 배포서버와 상호 작용하기 위한 JavaScript 및 Node.js REPL 환경입니다. 자세한 내용은 mongosh를 참조하세요.

MongoDB Compass는 시각적 환경에서 MongoDB 데이터를 쿼리, 애그리게이션 및 분석할 수 있는 강력한 GUI입니다. 자세한 내용은 MongoDB Compass를 참조하세요.

MongoDB에서 데이터베이스는 하나 이상의 문서 컬렉션을 보유합니다.

사용할 데이터베이스를 선택하려면 Atlas에 로그인하고 다음을 수행합니다.

1
2

사용할 데이터베이스를 선택하려면 mongosh에서 다음 예와 같이 use <db> 문을 실행합니다.

use myDB

사용할 데이터베이스를 선택하려면 다음 단계를 완료하세요.

1

자세한 내용은 MongoDB에 연결을 참조하세요.

2

Databases 탭이 열리고 MongoDB 배포를 위한 기존 데이터베이스가 나열됩니다.

새 데이터베이스를 만들려면 Atlas에 로그인하여 다음을 수행합니다.

1
2
3

데이터베이스와 컬렉션 이름을 입력하여 데이터베이스와 첫 번째 컬렉션을 생성합니다.

4

성공적으로 생성되면 데이터베이스와 컬렉션이 Atlas UI의 왼쪽 창에 표시됩니다.

데이터베이스가 존재하지 않는 경우, MongoDB는 해당 데이터베이스에 사용할 데이터를 처음 저장할 때 데이터베이스를 생성합니다. 따라서 존재하지 않는 데이터베이스로 전환하여 mongosh에서 다음 작업을 수행할 수 있습니다.

use myNewDB
db.myNewCollection1.insertOne( { x: 1 } )

insertOne() 작업은 데이터베이스 myNewDB와 컬렉션 myNewCollection1이 아직 존재하지 않는 경우 둘 다 생성합니다. 데이터베이스와 컬렉션 이름이 모두 MongoDB 이름 지정 제한을 준수하는지 확인하세요.

1
2
3
4

MongoDB는 문서를 컬렉션에 저장합니다. 컬렉션은 관계형 데이터베이스의 테이블과 유사합니다.

MongoDB 문서 컬렉션입니다.
클릭하여 확대

만약 컬렉션이 존재하지 않는다면 MongoDB는 해당 컬렉션의 데이터를 처음 저장할 때 컬렉션을 생성합니다.

새 컬렉션을 만들려면 Atlas에 로그인하여 다음을 수행합니다.

1
2
3
4

성공적으로 생성되면 컬렉션이 Atlas UI의 데이터베이스 아래에 표시됩니다.

db.myNewCollection2.insertOne( { x: 1 } )
db.myNewCollection3.createIndex( { y: 1 } )

insertOne()createIndex() 연산은 모두 컬렉션이 아직 존재하지 않는 경우 해당 컬렉션을 생성합니다. 컬렉션 이름이 MongoDB 이름 지정 제한을 준수하는지 확인하세요.

1
2
3
4

새 컬렉션을 만들려면 Atlas에 로그인하여 다음을 수행합니다.

1
2
3
4

다음 유형의 컬렉션 중 하나를 만들 수 있습니다.

  • 고정 사이즈 컬렉션

    고정 사이즈 컬렉션을 만들도록 선택한 경우 최대 크기를 바이트 단위로 지정합니다.

  • Time Series 컬렉션

    Time series 컬렉션을 생성하도록 선택한 경우 시간 필드와 세분성을 지정합니다. 선택적으로 메타 필드와 컬렉션의 이전 데이터가 만료되는 시간을 지정할 수 있습니다.

  • 클러스터형 인덱스 컬렉션

    클러스터형 컬렉션을 만들기로 선택한 경우 클러스터형 인덱스 키 값과 클러스터형 인덱스의 이름을 지정해야 합니다.

5

성공적으로 생성되면 컬렉션이 Atlas UI의 데이터베이스 아래에 표시됩니다.

MongoDB는 최대 크기 설정 또는 문서 검증 규칙 설정과 같은 다양한 옵션을 사용하여 컬렉션을 명시적으로 생성할 수 있는 db.createCollection() 메서드를 제공합니다. 이러한 옵션을 지정하지 않은 경우 컬렉션에 데이터를 처음 저장할 때 MongoDB가 새 컬렉션을 생성하므로 컬렉션을 명시적으로 생성할 필요가 없습니다.

이러한 컬렉션 옵션을 수정하려면 collMod를 참조하세요.

1
2
3
4

MongoDB Compass는 컬렉션에 대해 구성할 수 있는 다음과 같은 추가 기본 설정을 제공합니다.

기본적으로 컬렉션은 문서가 동일한 스키마를 가질 필요가 없습니다. 즉, 단일 컬렉션의 문서가 동일한 필드 집합을 가질 필요는 없으며 필드의 데이터 유형은 컬렉션 내의 문서마다 다를 수 있습니다.

그러나 업데이트 및 삽입 작업 중에 컬렉션에 대한 문서 유효성 검사 규칙 을 시행할 수 있습니다. 자세한 내용은 스키마 유효성 검사 를 참조하세요.

MongoDB Atlas에서 호스팅되는 배포의 경우,Performance Advisor 및 MongoDB Atlas UI는 일반적인 스키마 설계 문제를 감지하고 MongoDB 권장사항을 따르는 수정을 제안합니다. 자세히 알아보려면 스키마 제안을 참조하세요.

컬렉션에서 문서의 구조를 변경(예: 새 필드 추가, 기존 필드 제거, 필드 값을 새 유형으로 변경)하려면 문서를 새 구조로 업데이트하세요.

컬렉션에는 변경할 수 없는 UUID 가 할당됩니다. 컬렉션 UUID는 샤드 클러스터의 복제본 세트 및 샤드의 모든 멤버에서 동일하게 유지됩니다.

컬렉션의 UUID를 조회하려면 listCollections 명령 또는 db.getCollectionInfos() 메서드를 실행합니다.

돌아가기

시작하기

이 페이지의 내용