db.collection.updateSearchIndex()
정의
버전 7.0에 새로 추가됨: (6.0.7부터 사용 가능)
기존 Atlas Search 인덱스 를 업데이트합니다.
중요
Mongo쉬 방법
이 페이지에서는 mongosh
메서드에 대해 설명합니다. 이는 데이터베이스 명령 또는 Node.js와 같은 언어별 드라이버에 대한 설명서가 아닙니다.
데이터베이스 명령의 경우 updateSearchIndex
명령을 참조하세요.
MongoDB API 드라이버의 경우 언어별 MongoDB 드라이버 설명서를 참조하세요.
호환성
이 메서드는 다음 환경에서 호스팅되는 배포에서 사용할 수 있습니다.
MongoDB Atlas: 클라우드에서의 MongoDB 배포를 위한 완전 관리형 서비스
중요
이 명령은 M0, M2 및 M5 클러스터 또는 서버리스 인스턴스에서 지원되지 않습니다. 자세한 내용은 지원되지 않는 명령을 참조하세요.
구문
명령 구문:
db.<collection>.updateSearchIndex( <name>, { <definition> } )
명령 필드
updateSearchIndex()
는 다음 필드를 사용합니다.
필드 | 유형 | 필요성 | 설명 |
---|---|---|---|
name | 문자열 | 필수 사항 | 업데이트할 검색 인덱스의 이름입니다. |
definition | 문서 | 필수 사항 | 업데이트된 인덱스 정의를 설명하는 문서입니다. definition 구문에 대한 자세한 내용은 Atlas Search 인덱스 정의 구문을 참조하세요. |
인덱스 정의 구문 검색
검색 인덱스 정의에는 다음 필드가 사용됩니다.
{ analyzer: "<analyzer-for-index>", searchAnalyzer: "<analyzer-for-query>", mappings: { dynamic: <boolean>, fields: { <field-definition> } }, analyzers: [ <custom-analyzer> ], storedSource: <boolean> | { <stored-source-definition> }, synonyms: [ { name: "<synonym-mapping-name>", source: { collection: "<source-collection-name>" }, analyzer: "<synonym-mapping-analyzer>" } ] }
필드 | 유형 | 필요성 | 설명 |
---|---|---|---|
analyzer | 문자열 | 옵션 | 인덱싱할 때 필드에 적용할 분석기 를 지정합니다.string 이 필드를 생략하면 인덱스는 표준 분석기를 사용합니다. |
searchAnalyzer | 문자열 | 옵션 | 텍스트를 검색하기 전에 쿼리 텍스트에 적용할 분석기 를 지정합니다. 이 필드를 생략하면 인덱스는
|
mappings | 객체 | 필수 사항 | 이 인덱스에 대해 서로 다른 경로에 있는 필드를 인덱싱하는 방법을 지정합니다. |
mappings.dynamic | 부울 | 옵션 | 이 인덱스에 대한 동적 필드 매핑을 활성화하거나 비활성화합니다.
생략하는 경우 기본값은 |
mappings.fields | 문서 | 조건부 | 동적 매핑이 비활성화된 경우에만 필요합니다. 인덱싱할 필드를 지정합니다. 자세히 알아보려면 필드 매핑 정의를 참조하세요. |
analyzers | 배열 | 옵션 | 이 인덱스에서 사용할 사용자 지정 분석기 를 지정합니다. |
storedSource | 부울 또는 저장된 소스 정의 | 옵션 | 반환 된 저장 소스 옵션을 사용하여 수행된 쿼리에 대해 저장할 문서 필드를 지정합니다. Atlas Search에는 모든 데이터 유형 의 필드를 저장할 수 있습니다.
생략하는 경우 기본값은 자세히 알아보려면 Atlas Search 인덱스에서 저장된 소스 필드 정의를 참조하세요. |
synonyms | 옵션 | 인덱스 에 사용할 동의어 매핑을 지정합니다. 동의어를 구성하면 동일하거나 유사한 의미를 가진 단어를 인덱스 하고 검색 할 수 있습니다. 자세히 알아보려면 Atlas Search 인덱스에서 동의어 매핑 정의를 참조하세요. |
행동
updateSearchIndex()
새 인덱스 정의로 Atlas Triggers 인덱스 빌드를 합니다. 명령에서 응답을 받는 시점과 업데이트된 인덱스가 준비되는 시점 사이에는 지연이 있을 수 있습니다.
이전 인덱스 정의는 새 인덱스가 작성되는 동안 쿼리를 계속 지원할 수 있습니다. 새 인덱스 작성이 완료되면 이전 인덱스를 더 이상 사용할 수 없습니다. 검색 인덱스의 상태를 확인하려면 $listSearchIndexes
집계 단계를 사용합니다.
액세스 제어
배포서버에서 액세스 제어를 시행하는 경우 updateSearchIndex()
를 실행하는 사용자에게 데이터베이스 또는 컬렉션에 대한 updateSearchIndex
권한 조치가 있어야 합니다.
{ resource: { db : <database>, collection: <collection> }, actions: [ "updateSearchIndex" ] }
기본 제공 readWrite
및 restore
역할은 updateSearchIndex
권한을 제공합니다. 다음 예에서는 qa
데이터베이스에 readWrite
역할을 부여합니다.
db.grantRolesToUser( "<user>", [ { role: "readWrite", db: "qa" } ] )
예시
다음 예시에서는 새 Atlas Search 인덱스를 만든 다음 해당 인덱스를 업데이트합니다.
collection에 이라는 검색 인덱스를 만듭니다.
searchIndex01
movies
db.movies.createSearchIndex( "searchIndex01", { mappings: { dynamic: true }, storedSource: { exclude: [ "imdb.rating" ] } } ) searchIndex01
인덱스를 업데이트합니다:db.movies.updateSearchIndex( "searchIndex01", { mappings: { dynamic: true }, storedSource: { exclude: [ "movies" ] } } )