문서 메뉴
문서 홈
/
MongoDB 매뉴얼
/ / /

db.collection.dropIndexes()

이 페이지의 내용

  • 정의
  • 행동
db.collection.dropIndexes()

중요

Mongo쉬 방법

이 페이지에서는 mongosh 메서드를 설명합니다. 이는 데이터베이스 명령 또는 Node.js와 같은 언어별 드라이버에 대한 설명서가 아닙니다.

데이터베이스 명령에 대해서는 dropIndexes 명령을 참조하세요.

MongoDB API 드라이버의 경우 언어별 MongoDB 드라이버 설명서를 참조하세요.

레거시 mongo 셸 문서는 해당 MongoDB 서버 릴리스 문서를 참조하세요.

Mongo 셸 V4.4

컬렉션에서 지정된 인덱스(_id 필드의 인덱스와 마지막 남은 샤드 키 인덱스 제외)를 삭제합니다.

이 메서드를 사용하여 다음을 수행할 수 있습니다.

  • collection에서 _id 인덱스를 제외한 모든 항목을 삭제합니다.

    db.collection.dropIndexes()
  • collection에서 지정된 인덱스를 삭제합니다. 인덱스를 지정하려면 다음 중 하나를 사용하여 메서드를 전달합니다.

    • 인덱스 사양 문서(인덱스가 텍스트 인덱스가 아닌 경우, 인덱스 이름을 사용하여 삭제):

      db.collection.dropIndexes( { a: 1, b: 1 } )
    • 인덱스 이름

      db.collection.dropIndexes( "a_1_b_1" )

      인덱스 이름을 가져오려면 db.collection.getIndexes() 메서드를 사용하세요.

  • collection에서 지정된 인덱스를 삭제합니다. 삭제할 인덱스를 여러 개 지정하려면 메서드에 인덱스 이름 배열을 전달합니다.

    db.collection.dropIndexes( [ "a_1_b_1", "a_1", "a_1__id_-1" ] )

    인덱스 이름 배열에 존재하지 않는 인덱스가 포함되어 있으면 메서드는 지정된 인덱스를 삭제하지 않고 오류를 발생시킵니다.

    인덱스 이름을 가져오려면 db.collection.getIndexes() 메서드를 사용하세요.

db.collection.dropIndexes() 메서드는 다음과 같은 선택적 매개변수를 사용합니다.

매개 변수
유형
설명
indexes
문자열 또는 문자열의 문서 또는 배열

선택 사항. 삭제할 인덱스를 한 개 또는 여러 개 지정하세요.

collection에서 _id 인덱스를 제외한 모든 항목을 삭제하려면 매개변수를 생략합니다.

단일 인덱스를 삭제하려면 인덱스 이름, 인덱스 사양 문서(텍스트 인덱스가 아닌 경우) 또는 인덱스 이름의 배열을 지정합니다. 텍스트 인덱스를 삭제하려면 인덱스 사양 문서 대신 인덱스 이름 또는 인덱스 이름의 배열을 지정합니다.

여러 인덱스를 삭제하려면 인덱스 이름의 배열을 지정합니다.

MongoDB 6.0부터는 db.collection.dropIndexes()를 사용하여 마지막 남은 샤드 키 호환 인덱스를 제거하려고 하면 오류가 발생합니다. "*"db.collection.dropIndexes()에 전달하면 _id 인덱스와 마지막 남은 샤드 키 호환 인덱스(있는 경우)를 제외한 모든 인덱스가 제거됩니다.

MongoDB 5 부터 시작.2, 다른 인덱스에서 빌드가 진행 중이더라도 db.collection.dropIndexes() 를 사용하여 동일한 컬렉션의 기존 인덱스를 삭제할 수 있습니다. 이전 버전에서는 인덱스 빌드가 진행 중일 때 다른 인덱스를 삭제하려고 하면 BackgroundOperationInProgressForNamespace 오류가 발생했습니다.

dropIndexes() 작업은 제거되는 인덱스를 사용하는 쿼리만 종료합니다. 여기에는 쿼리 계획의 일부로 인덱스를 고려하는 쿼리가 포함될 수 있습니다.

db.collection.dropIndexes()은 작업 기간 동안 지정된 컬렉션에 대한 배타 락을 얻습니다. 컬렉션에 대한 모든 후속 작업은 db.collection.dropIndexes()이 잠금을 해제할 때까지 기다려야 합니다.

존재하지 않는 인덱스가 포함된 인덱스 이름 배열이 메서드에 전달되면 메서드는 지정된 인덱스를 삭제하지 않고 오류를 발생시킵니다.

_id 필드에서 기본 인덱스를 삭제할 수 없습니다.

텍스트 인덱스를 삭제하려면 인덱스 사양 문서 대신 인덱스 이름을 지정합니다.

db.collection.dropIndexes()에 지정된 인덱스가 아직 빌드 중이면 db.collection.dropIndexes()가 진행 중인 빌드를 중지하려고 시도합니다. 인덱스 빌드를 중지하면 빌드된 인덱스를 제거하는 것과 동일한 효과가 있습니다.

복제본 세트의 경우, 프라이머리에서 db.collection.dropIndexes()를 실행합니다. 프라이머리는 인덱스 빌드를 중단하고 관련 "abortIndexBuild" oplog 항목을 생성합니다. "abortIndexBuild" oplog 항목을 복제하는 세컨더리는 진행 중인 인덱스 빌드를 중지하고 빌드 작업을 삭제합니다. 인덱스 빌드 프로세스에 관한 자세한 설명은 인덱스 빌드 프로세스를 참조하세요.

currentOp을 사용하여 createIndexes 또는 db.collection.createIndexes() 작업과 관련된 인덱스 빌드를 식별합니다. 예는 활성 인덱싱 작업을 참조하세요.

MongoDB는 쿼리 플래너에서 인덱스를 숨기거나 숨기기를 해제할 수 있는 기능을 제공합니다. 플래너에서 인덱스를 숨기면 실제로 인덱스를 삭제하지 않고도 인덱스 삭제의 잠재적 영향을 평가할 수 있습니다.

평가 후 사용자가 인덱스를 제거하기로 결정하면 숨겨진 인덱스를 제거할 수 있습니다. 즉, 인덱스를 제거하기 위해 먼저 숨기기를 해제할 필요가 없습니다.

하지만 영향이 부정적이라면 사용자는 삭제된 인덱스를 다시 만들지 않고도 인덱스 숨김을 해제할 수 있습니다. 또한 인덱스는 숨겨진 상태에서도 완전히 유지되므로 숨김을 해제하면 인덱스를 즉시 사용할 수 있습니다.

숨겨진 인덱스에 대한 자세한 내용은 숨겨진 인덱스를 참조하세요.

← db.collection.dropIndexes()

이 페이지의 내용