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