문서 메뉴

문서 홈애플리케이션 개발MongoDB 매뉴얼

cursor.max()

이 페이지의 내용

  • 정의
  • 행동
  • 예제
cursor.max()

중요

Mongo쉬 방법

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

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

의 결과를 제한하기 위해 특정 인덱스에 대한 find() 배타적 상한을 지정합니다. 는 복합 키 인덱스의 max() 상한을 지정하는 방법을 제공합니다.

max() 메서드에는 다음과 같은 매개 변수가 있습니다.

매개변수
유형
설명
indexBounds
문서
인덱스 키의 배타적 상한선입니다.

indexBounds 매개변수의 프로토타입 형식은 다음과 같습니다.

{ field1: <max value>, field2: <max value2> ... fieldN:<max valueN> }

필드는 특정 인덱스의 모든에 순서대로 해당합니다.

참고

인덱스 사용하기

max() 메서드와 함께 인덱스를 사용하려면 find() 쿼리가 _id 필드의 동등 조건인 경우를 제외하고hint()메서드를 사용하여 사용하려는 인덱스를 지정해야 합니다.

다음도 참조하세요.

max() 는 주로 mongos (샤딩) 프로세스를 지원하기 위해 존재합니다.

max() 에는 필드에 대한 인덱스가 필요하고 쿼리가 이 인덱스를 사용하도록 강제하므로 가능하면 쿼리에 $lt 연산자를 선호할 수 있습니다. 다음 예시를 살펴보겠습니다.

db.products.find( { _id: { $in: [ 6, 7 ] } } ).max( { price: NumberDecimal("1.39") } ).hint( { price: 1 } )

쿼리는 _id 의 인덱스가 더 좋더라도 price 필드의 인덱스를 사용합니다.

max()min() 와 함께 사용하여 범위를 지정하는 경우:

min()max() 메서드는 시스템에서 일반적인 쿼리 계획을 피해야 함을 나타냅니다. 인덱스 경계가 min()max() 에 지정된 값으로 명시적으로 지정되는 인덱스 스캔을 구성합니다.

경고

두 경계 중 하나를 지정하지 않으면 쿼리 계획은 한 쪽에서 제한이 없는 인덱스 스캔이 됩니다. 이는 두 연산자를 모두 포함하지 않거나 두 연산자를 모두 사용하여 인덱스 스캔을 더 엄격하게 제한하는 쿼리에 비해 성능이 저하될 수 있습니다.

참고

MongoDB 부터 4 시작.2, 를 실행하려면 메서드를 사용하여 특정 인덱스를 명시적으로 지정해야 hint() max() 합니다. 단, 쿼리가 필드의 동등 find() 조건인 _id 경우 힌트를 줄 필요가 { _id: <value> } 없습니다. .

아래 예시에서는 다음 문서를 포함하는 products 라는 이름의 샘플 컬렉션을 만듭니다.

db.products.insertMany([
{ "_id" : 1, "item" : "apple", "type" : "honey crisp", "price" : NumberDecimal("1.99") },
{ "_id" : 2, "item" : "apple", "type" : "fuji", "price" : NumberDecimal("1.99") },
{ "_id" : 3, "item" : "apple", "type" : "jonagold", "price" : NumberDecimal("1.29") },
{ "_id" : 4, "item" : "apple", "type" : "jonathan", "price" : NumberDecimal("1.29") },
{ "_id" : 5, "item" : "apple", "type" : "mcintosh", "price" : NumberDecimal("1.29") },
{ "_id" : 6, "item" : "apple", "type" : "cortland", "price" : NumberDecimal("1.29") },
{ "_id" : 7, "item" : "orange", "type" : "cara cara", "price" : NumberDecimal("2.99") },
{ "_id" : 9, "item" : "orange", "type" : "satsuma", "price" : NumberDecimal("1.99") },
{ "_id" : 8, "item" : "orange", "type" : "valencia", "price" : NumberDecimal("0.99") },
{ "_id" : 10, "item" : "orange", "type" : "navel", "price" : NumberDecimal("1.39") }
])

컬렉션에 대해 다음 인덱스를 생성합니다.

db.products.createIndexes( [
{ "item" : 1, "type" : 1 },
{ "item" : 1, "type" : -1 },
{ "price" : 1 }
] )
  • 인덱스의max() 순서를 사용하여 { item: 1, type: 1 } item apple type jonagold는 와 동일한 및 와 동일한 의 경계 아래에 있는 문서로 쿼리를 제한합니다.

    db.products.find().max( { item: 'apple', type: 'jonagold' } ).hint( { item: 1, type: 1 } )

    이 쿼리는 다음 문서를 반환합니다.

    { "_id" : 6, "item" : "apple", "type" : "cortland", "price" : NumberDecimal("1.29") }
    { "_id" : 2, "item" : "apple", "type" : "fuji", "price" : NumberDecimal("1.99") }
    { "_id" : 1, "item" : "apple", "type" : "honey crisp", "price" : NumberDecimal("1.99") }
  • 인덱스 { price: 1 } 의 순서를 사용하여, max()price 의 인덱스 키 바운드 미만인 문서로 쿼리를 NumberDecimal("1.99")min() 와 같거나 또는 그 이상의 문서로 제한합니다. price NumberDecimal("1.39") 과 같습니다.

    db.products.find().min( { price: NumberDecimal("1.39") } ).max( { price: NumberDecimal("1.99") } ).hint( { price: 1 } )

    이 쿼리는 다음 문서를 반환합니다.

    { "_id" : 10, "item" : "orange", "type" : "navel", "price" : NumberDecimal("1.39") }
← cursor.map()

이 페이지의 내용