db.collection.renameCollection()
드라이버가 포함된 MongoDB
이 페이지에서는 mongosh
메서드를 설명합니다. MongoDB 드라이버에서 해당 메서드를 보려면 프로그래밍 언어의 해당 페이지를 참조하세요.
정의
db.collection.renameCollection(target, dropTarget)
컬렉션의 이름을 변경합니다.
renameCollection
데이터베이스 명령에 대한 래퍼(wrapper)를 제공합니다.Parameter유형설명target
문자열
collection의 새 이름입니다. 문자열을 따옴표로 묶습니다. 이름 지정 제한 사항을 참조하세요.
dropTarget
부울
선택 사항.
true
인 경우mongod
에서 컬렉션 이름을 바꾸기 전에renameCollection
의target
을 제거합니다. 기본값은false
입니다.
호환성
이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.
MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스
참고
이 명령은 모든 MongoDB Atlas 클러스터에서 지원됩니다. 모든 명령에 대한 Atlas 지원에 관해 자세히 알아보려면 지원되지 않는 명령을 참조하십시오.
MongoDB Enterprise: MongoDB의 구독 기반 자체 관리 버전
MongoDB Community: MongoDB의 소스 사용 가능 무료 자체 관리 버전
행동
db.collection.renameCollection()
메서드는 지정된 컬렉션과 연결된 메타데이터를 변경하여 컬렉션 내에서 작동합니다.
추가 경고 및 메시지는 문서 renameCollection
를 참조하세요.
경고
db.collection.renameCollection()
메서드와 renameCollection
명령은 열린 커서를 무효화합니다. 이는 소스나 대상 컬렉션에서 열린 기존 변경 스트림에 대한 무효화 이벤트를 생성하며 현재 이름이 변경된 컬렉션에서 데이터를 반환하는 중인 쿼리도 중단됩니다.
이 메서드에는 다음과 같은 제한 사항이 있습니다.
db.collection.renameCollection()
컬렉션은 데이터베이스 간에 이동할 수 없습니다. 이러한 이름 변경 작업에는renameCollection
을 사용하세요.뷰의 이름은 바꿀 수 없습니다.
db.collection.renameCollection()
Time Series 컬렉션에서는 지원되지 않습니다.컬렉션 이름을 컬렉션 자체로 변경할 수는 없습니다. 컬렉션의 이름을 컬렉션 자체로 바꾸려고 하면
IllegalOperation
오류가 발생합니다.
샤딩된 클러스터의 리소스 잠금
버전 5.0에서 변경됨
샤딩된 클러스터에서 샤딩된 컬렉션이나 샤딩되지 않은 컬렉션의 이름을 변경할 때 소스 및 대상 컬렉션은 모든 샤드에서만 독점적으로 잠깁니다. 소스 및 대상 컬렉션에 대한 후속 작업은 이름 바꾸기 작업이 완료될 때까지 기다려야 합니다.
MongoDB 잠금에 대한 자세한 내용은 FAQ: 동시성을 참조하세요.
복제본 세트의 리소스 잠금
renameCollection()
은 연산 기간 동안 소스 및 타깃 컬렉션에 대한 배타적 잠금을 획득합니다. 컬렉션에 대한 모든 후속 연산은 renameCollection()
이 완료될 때까지 기다려야 합니다.
다음과의 상호 작용 mongodump
--oplog
옵션으로 시작된 mongodump
는 덤프 프로세스 중에 클라이언트가 db.collection.renameCollection()
을 실행하면 실패합니다. 자세한 내용은 mongodump.--oplog
를 참조하세요.
예시
컬렉션 객체에서 db.collection.renameCollection()
메서드를 호출합니다. 예시:
db.rrecord.renameCollection("record")
이 작업은 rrecord
컬렉션의 이름을 record
(으)로 변경합니다. 대상 이름( record
)이 기존 컬렉션의 이름이면 작업이 실패합니다.