Learn why MongoDB was named a leader in the 2024 Gartner® Magic Quadrant™
Read the blog
Docs Menu

db.getCollectionNames()

db.getCollectionNames()

현재 데이터베이스에 있는 모든 컬렉션과 의 이름이 포함된 배열을 반환합니다. 또는 액세스 제어를 사용하여 실행하는 경우 사용자의 권한에 따라 컬렉션의 이름을 반환합니다. 자세한 내용은 필수 액세스 권한을 참조하세요.

이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.

  • MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스

참고

이 명령은 모든 MongoDB Atlas 클러스터에서 지원됩니다. 모든 명령에 대한 Atlas 지원에 관해 자세히 알아보려면 지원되지 않는 명령을 참조하십시오.

db.getCollectionNames()는 다음과 같습니다.

db.runCommand(
{
listCollections: 1.0,
authorizedCollections: true,
nameOnly: true
}
)
  • 필수 액세스 권한(데이터베이스에 대해 listCollections 작업을 부여하는 권한)이 있는 사용자의 경우 이 메서드는 데이터베이스에 필요한 모든 컬렉션의 이름을 나열합니다.

  • 필수 액세스 권한이 없는 사용자의 경우, 이 메서드는 사용자에게 권한이 있는 컬렉션만 나열합니다. 그 예로 사용자에게 데이터베이스의 특정 컬렉션에 대한 find이(가) 있다면 이 메서드가 해당 컬렉션만을 반환합니다.

MongoDB 4.2부터 db.getCollectionNames()를 발급한 클라이언트가 작업이 완료되기 전에 연결을 끊는 경우, MongoDB는 db.getCollectionNames()를 사용하여 를killOp을 종료로 표시합니다.

복제본 세트 노드에서 실행하는 경우 listCollections 연산을 수행하려면 노드가 PRIMARY 또는 SECONDARY 상태여야 합니다. 노드가 STARTUP2와 같은 다른 상태이면 연산 오류가 발생합니다.

다음은 records 데이터베이스에 있는 모든 컬렉션의 이름을 반환합니다.

use records
db.getCollectionNames()

이 메서드는 배열의 collection 이름을 반환하며 다음과 같습니다.

[ "employees", "products", "mylogs", "system.indexes" ]