반환된 결과 건너뛰기
이 페이지의 내용
개요
이 가이드에서는 MongoDB 코틀린(Kotlin) 드라이버를 사용하여 읽기 작업에서 반환된 지정된 수의 결과를 건너뛰는 방법을 배울 수 있습니다.
skip()
메서드를 사용하여 쿼리의 반환된 결과에 대한 결과를 건너뛸 수 있습니다. $skip
집계 단계를 지정하여 집계 파이프라인의 특정 단계에서 문서를 건너뛸 수도 있습니다.
메서드는 FindFlow가반환한 문서 목록의 시작 부분에서 생략할 문서 수를 지정하는 정수를 사용합니다.skip()
다음과 같이 skip()
메서드를 사용하여 처음 두 문서를 건너뛸 수 있습니다.
collection.find().skip(2)
Aggregates.skip() 집계 파이프라인의 선택적 단계로, 이전 단계의 결과 시작 부분에서 생략할 문서 수를 지정합니다.
다음과 같이 Aggregates.skip()
메서드를 사용하여 처음 두 문서를 건너뛸 수 있습니다.
val filter = Filters.empty() val results = collection.aggregate(listOf( Aggregates.match(filter), Aggregates.skip(2)) )
예시
다음 예는 8가지 색상의 페인트를 판매하는 페인트 가게에 관한 예입니다. 가장 좋은 색상은 다른 색상보다 더 빨리 판매됩니다. 어느 날 고객이 가장 많이 판매되는(재고가 가장 낮은) 색상 세 가지가 무엇인지 질문합니다. 페인트 가게는 collection의 필드에 있는 재고를 qty
paint_inventory
추적합니다.
{ "_id": 1, "color": "red", "qty": 5 } { "_id": 2, "color": "purple", "qty": 10 } { "_id": 3, "color": "blue", "qty": 9 } { "_id": 4, "color": "white", "qty": 6 } { "_id": 5, "color": "yellow", "qty": 11 } { "_id": 6, "color": "pink", "qty": 3 } { "_id": 7, "color": "green", "qty": 8 } { "_id": 8, "color": "orange", "qty": 7 }
이 데이터는 다음 Kotlin 데이터 클래스로 모델링됩니다.
data class PaintOrder( val id: Int, val qty: Int, val color: String )
이 시나리오를 해결하려면 페인트 매장에서 빈 필터를 사용하여 paint_inventory
collection을 쿼리하고 qty
필드를 기준으로 문서를 정렬하고 처음 5개의 결과를 생략해야 합니다.
FindIterable 사용
val filter = Filters.empty() val results = collection.find(filter) .sort(descending(PaintOrder::qty.name)) .skip(5) results.collect { println(it) }
PaintOrder(id=4, qty=6, color=white) PaintOrder(id=1, qty=5, color=red) PaintOrder(id=6, qty=3, color=pink)
find()
메서드는 모든 문서를 반환합니다.sort()
메서드는qty
필드를 기준으로 가장 높은 문서부터 가장 낮은 문서까지 표시할 문서를 지정합니다.skip()
메서드는 처음 5개의 문서를 생략하도록 지정합니다.
집계 사용하기
val filter = Filters.empty() val aggregate = listOf( Aggregates.match(filter), Aggregates.sort(descending(PaintOrder::qty.name)), Aggregates.skip(5) ) val findFlow = collection.aggregate(aggregate) findFlow.collect { println(it) }
PaintOrder(id=4, qty=6, color=white) PaintOrder(id=1, qty=5, color=red) PaintOrder(id=6, qty=3, color=pink)
match()
단계는 모든 문서를 반환합니다.sort()
단계에서는qty
필드를 기준으로 가장 높은 문서부터 가장 낮은 문서까지 표시할 문서를 지정합니다.skip()
단계는 처음 5개의 문서를 생략하도록 지정합니다.
페인트 가게에서 쿼리를 실행한 후 가장 많이 판매되는 세 가지 색상인 분홍, 빨강, 흰색을 발견했습니다.
참고
건너뛰기 값이 쿼리에 대해 일치하는 문서 수보다 크거나 같으면 해당 쿼리는 문서를 반환하지 않습니다.
앞의 예의 skip()
메서드가 처음 9개의 문서를 건너뛰면 지정된 수량이 일치하는 문서 수를 초과하기 때문에 결과가 반환되지 않습니다.
val filter = Filters.empty() val emptyQuery = listOf( Aggregates.match(filter), Aggregates.sort(descending(PaintOrder::qty.name)), Aggregates.skip(9) ) val findFlow = collection.aggregate(emptyQuery) findFlow.collect { println(it) }