결과 정렬
개요
이 가이드에서는 정렬 작업을 사용하여 MongoDB Java 드라이버로 읽기 작업의 결과를 정렬하는 방법을 배울 수 있습니다.
정렬 작업은 지정된 정렬 기준 에 따라 쿼리에서 반환된 문서를 정렬합니다. 정렬 기준은 데이터 정렬 방법을 설명하는 MongoDB에 전달하는 규칙입니다. 정렬 기준의 몇 가지 예는 다음과 같습니다.
가장 작은 숫자에서 가장 큰 숫자로
가장 이른 시간부터 가장 늦은 시간까지
이름별 알파벳 순서
다음을 수행하려는 경우 이 가이드를 읽어야 합니다.
오름차순 정렬과 내림차순 정렬을 수행합니다.
정렬 기준을 결합합니다.
이 가이드의 예제에서는 다음 문서가 포함된 샘플 컬렉션을 사용합니다.
{"_id": 1, "letter": "c", "food": "coffee with milk"} {"_id": 3, "letter": "a", "food": "maple syrup"} {"_id": 4, "letter": "b", "food": "coffee with sugar"} {"_id": 5, "letter": "a", "food": "milk and cookies"} {"_id": 2, "letter": "a", "food": "donuts and coffee"} {"_id": 6, "letter": "c", "food": "maple donut"}
정렬 방법
쿼리로 검색된 결과를 정렬하고 집계 파이프라인 내에서 결과를 정렬할 수 있습니다. 쿼리 결과를 정렬하려면 FindIterable
인스턴스의 sort()
메서드를 사용합니다. 집계 파이프라인 내에서 결과를 정렬하려면 Aggregates.sort()
정적 팩토리 메서드를 사용합니다. 이 두 메서드 모두 Bson
인터페이스를 구현하는 객체를 인수로 받습니다. 자세한 내용은 BSON 인터페이스에 대한 API 설명서를 참조하세요.
다음과 같이 FindIterable
인스턴스의 sort()
메서드를 사용할 수 있습니다.
import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> collection.find().sort(ascending("_id"));
다음과 같이 집계 파이프라인 내에서 Aggregates.sort()
메서드를 사용할 수 있습니다.
import com.mongodb.client.model.Aggregates; import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> collection.aggregate(Arrays.asList(Aggregates.sort(ascending("_id"))));
앞의 코드 스니펫은 샘플 컬렉션 의 문서를 _id
필드의 가장 작은 값에서 가장 큰 값으로 정렬합니다.
{"_id": 1, "letter": "c", "food": "coffee with milk"} {"_id": 2, "letter": "a", "food": "donuts and coffee"} {"_id": 3, "letter": "a", "food": "maple syrup"} ...
앞의 코드 스니펫에서는 Sorts
빌더 클래스를 사용하여 정렬 기준을 지정합니다. Bson
인터페이스를 구현하는 모든 클래스를 사용하여 정렬 기준을 지정할 수 있지만 Sorts
빌더를 통해 정렬 기준을 지정하는 것이 좋습니다. Sorts
빌더 클래스에 대한 자세한 내용은정렬 가이드의 가이드를 참조하세요.
이 섹션의 클래스 및 인터페이스에 대한 자세한 내용은 다음 API 설명서를 참조하세요.
정렬 방향
정렬 방향은 오름차순 또는 내림차순 중 하나일 수 있습니다. 오름차순 정렬은 결과가 가장 작은 순서에서 가장 큰 순서로 정렬됩니다. 내림차순 정렬은 결과가 가장 큰 순서에서 가장 작은 순서로 정렬됩니다.
다음은 오름차순으로 정렬된 데이터의 몇 가지 예입니다.
숫자: 1, 2, 3, 43, 43, 55, 120
날짜: 1990-03-10, 1995-01-01, 2005-10-30, 2005-12-21
단어(ASCII): 바나나, 딜, 당근, 오이, 후무스
다음은 내림차순으로 정렬된 데이터의 몇 가지 예입니다.
숫자: 100, 30, 12, 12, 9, 3, 1
날짜: 2020-01-01, 1998-12-11, 1998-12-10, 1975-07-22
단어(역 ASCII): 배,포도,사과,치즈
다음 하위 섹션에서는 이러한 정렬 기준을 지정하는 방법을 보여 줍니다.
오름차순
오름차순 정렬을 지정하려면 Sorts.ascending()
정적 팩토리 메서드를 사용합니다. Sorts.ascending()
메서드에 정렬할 필드의 이름을 오름차순으로 전달합니다.
다음과 같이 sort()
메서드에 Sorts.ascending()
메서드의 출력을 전달하여 필드에 오름차순 정렬을 지정할 수 있습니다.
import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> collection.find().sort(ascending("<field name>"));
앞의 sort()
메서드는 지정된 필드 이름을 기준으로 가장 작은 것부터 큰 것 순으로 정렬하여 컬렉션의 문서를 반복할 수 있는 FindIterable
객체를 반환합니다.
다음 코드 예제에서는 ascending()
메서드를 사용하여 _id
필드를 기준으로 샘플 컬렉션 을 정렬합니다.
import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> List<Document> results = new ArrayList<>(); collection.find().sort(ascending("_id")).into(results); for (Document result : results) { System.out.println(result.toJson()); }
앞의 코드의 출력은 다음과 유사합니다.
{"_id": 1, "letter": "c", "food": "coffee with milk"} {"_id": 2, "letter": "a", "food": "donuts and coffee"} {"_id": 3, "letter": "a", "food": "maple syrup"} ...
내림차순
내림차순 정렬을 지정하려면 Sorts.descending()
정적 팩토리 메서드를 사용합니다. Sorts.descending()
메서드에 정렬할 필드의 이름을 내림차순으로 전달합니다.
다음 코드 스니펫은 _id
필드에 내림차순 정렬을 지정하는 방법을 보여줍니다.
import static com.mongodb.client.model.Sorts.descending; // <MongoCollection setup code here> collection.find().sort(descending("_id"));
앞의 코드 스니펫은 샘플 컬렉션의 문서를 내림차순으로 반환합니다.
{"_id": 6, "letter": "c", "food": "maple donut"} {"_id": 5, "letter": "a", "food": "milk and cookies"} {"_id": 4, "letter": "b", "food": "coffee with sugar"} ...
타이 처리
결과를 정렬하는 데 사용하는 필드에 둘 이상의 문서에 동일한 값이 있는 경우 타이가 발생합니다. MongoDB는 타이가 발생할 경우 정렬 순서를 보장하지 않습니다. 예를 들어 다음 코드를 사용하여 샘플 컬렉션에 정렬을 적용할 때 타이가 발생한다고 가정해 보겠습니다.
import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> collection.find().sort(ascending("letter"));
쿼리와 일치하는 여러 문서에 정렬을 수행하는 필드에 대한 '값'이 포함되어 있으므로 다음 문서는 어떤 순서로든 반환될 수 있습니다.
{"_id": 3, "letter": "a", "food": "maple syrup"} {"_id": 5, "letter": "a", "food": "milk and cookies"} {"_id": 2, "letter": "a", "food": "donuts and coffee"}
값이 동일한 필드가 있는 문서에 대해 특정 정렬 순서를 보장해야 하는 경우, 동점인 경우 정렬할 추가 필드를 지정할 수 있습니다.
다음과 같이 letter
필드와 그 뒤의 _id
필드에 오름차순 정렬을 지정할 수 있습니다.
import static com.mongodb.client.model.Sorts.ascending; // <MongoCollection setup code here> collection.find().sort(ascending("letter", "_id"));
앞의 코드 스니펫은 샘플 컬렉션 의 문서를 다음 순서로 반환합니다.
{"_id": 2, "letter": "a", "food": "donuts and coffee"} {"_id": 3, "letter": "a", "food": "maple syrup"} {"_id": 5, "letter": "a", "food": "milk and cookies"} {"_id": 4, "letter": "b", "food": "coffee with sugar"} {"_id": 1, "letter": "c", "food": "coffee with milk"} {"_id": 6, "letter": "c", "food": "maple donut"}
정렬 기준 결합
정렬 기준을 결합하려면 Sorts.orderBy()
정적 팩토리 메서드를 사용합니다. 이 메서드는 정렬된 정렬 기준 목록을 포함하는 객체를 구성합니다. 정렬을 수행할 때 가장 왼쪽 정렬 기준이 동점인 경우 목록의 다음 정렬 기준을 사용하여 순서를 결정합니다.
다음 코드 스니펫에서는 orderBy()
메서드를 사용하여 letter
필드에서 내림차순 정렬을 수행하고, 동점인 경우 _id
필드에서 오름차순 정렬을 수행하여 데이터를 정렬합니다.
import static com.mongodb.client.model.Sorts.orderBy; import static com.mongodb.client.model.Sorts.ascending; import static com.mongodb.client.model.Sorts.descending; // <MongoCollection setup code here> Bson orderBySort = orderBy(descending("letter"), ascending("_id")); collection.find().sort(orderBySort);
앞의 코드 스니펫은 샘플 컬렉션 의 문서를 다음 순서로 반환합니다.
{"_id": 1, "letter": "c", "food": "coffee with milk"} {"_id": 6, "letter": "c", "food": "maple donut"} {"_id": 4, "letter": "b", "food": "coffee with sugar"} {"_id": 2, "letter": "a", "food": "donuts and coffee"} {"_id": 3, "letter": "a", "food": "maple syrup"} {"_id": 5, "letter": "a", "food": "milk and cookies"}
텍스트 검색
컬렉션의 텍스트 인덱스 로 지정된 각 결과 필드의 값이 Atlas Search 과 얼마나 일치하는지를 기준으로 string 텍스트 Atlas Search 결과의 순서를 지정할 수 string 있습니다. 텍스트 Atlas Search는 각 결과가 Atlas Search string 과 얼마나 일치하는지를 나타내는 숫자 텍스트 점수 를 할당합니다. Sorts.metaTextScore()
정적 팩토리 메서드를 사용하여 텍스트 점수를 기준으로 정렬하는 정렬 기준을 작성합니다.
중요
텍스트 인덱스 생성 확인
텍스트 Atlas Search를 수행하려면 컬렉션에 대한 텍스트 인덱스 가 필요합니다. 텍스트 인덱스를 만드는 방법에 대한 자세한 내용은 서버 매뉴얼 설명서를 참조하세요.
다음 코드 예시에서는 Sorts.metaTextScore()
메서드를 사용하여 샘플 컬렉션에서 텍스트 검색 결과를 정렬하는 방법을 보여 줍니다. 이 코드 예시에서는 필터, 인덱스 및 프로젝션 빌더를 사용합니다. 이 코드 예시에서는 다음 작업을 수행합니다.
food
필드에 샘플 컬렉션 에 대한 텍스트 인덱스를 생성합니다. 컬렉션에 이미 존재하는 인덱스를 지정하여createIndex()
를 호출하면 작업을 통해 새 인덱스가 생성되지 않습니다.Atlas Search에서 "maple donut" 구문에 대한 텍스트를 실행합니다.
텍스트 점수를 쿼리 결과에
score
필드로 프로젝션합니다.텍스트 점수를 기준으로 결과를 정렬합니다(가장 일치하는 항목 먼저).
import com.mongodb.client.model.Sorts; import com.mongodb.client.model.Projections; import com.mongodb.client.model.Filters; import com.mongodb.client.model.Indexes; // <MongoCollection setup code here> collection.createIndex(Indexes.text("food")); Bson metaTextScoreSort = Sorts.metaTextScore("score"); Bson metaTextScoreProj = Projections.metaTextScore("score"); String searchTerm = "maple donut"; Bson searchQuery = Filters.text(searchTerm); collection.find(searchQuery) .projection(metaTextScoreProj) .sort(metaTextScoreSort) .into(results); for (Document result : results) { System.out.println(result.toJson()); }
앞의 코드의 출력은 다음과 유사합니다.
{"_id": 6, "letter": "c", "food": "maple donut", "score": 1.5} {"_id": 2, "letter": "a", "food": "donuts and coffee", "score": 0.75} {"_id": 3, "letter": "a", "food": "maple syrup", "score": 0.75}
참고
Atlas Search 이상에서 텍스트 동작 MongoDB 4.4
MongoDB 4.4 이상에서는 텍스트 검색 구조가 변경되었습니다. 더 이상 텍스트 점수를 기준으로 정렬하기 위해 Projections.metaTextScore()
를 FindIterable
인스턴스 에 프로젝트 하지 않습니다. 또한 정렬에 사용되는 $meta
텍스트 점수 집계 작업에서 지정한 필드 이름은 무시됩니다. 즉, Sorts.metaTextScore()
에 전달한 필드 이름 인수는 무시됩니다.
이 섹션의 클래스에 대한 자세한 내용은 다음 API 설명서를 참조하세요.
자세한 내용은 Sorts 클래스 를 참조하세요. API 문서. $text 쿼리 연산자 및 $meta 집계 파이프라인 연산자 에 대한 자세한 내용은 서버 매뉴얼 문서를 참조하세요.