다음은 MongoDB에서 정렬된 데이터로 고유한 값을 가져오는 쿼리입니다.
db.yourCollectionName.distinct("yourFieldName").sort();
먼저 문서로 컬렉션을 생성하겠습니다.
>db.getDistinctWithSortedDataDemo.insertOne({"StudentId":10,"StudentName":"John","StudentAge":23}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e3315e86fd1496b38c3") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":20,"StudentName":"Carol","StudentAge":21}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e3e15e86fd1496b38c4") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":10,"StudentName":"John","StudentAge":23}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e4415e86fd1496b38c5") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":30,"StudentName":"Chris","StudentAge":22}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e5115e86fd1496b38c6") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":20,"StudentName":"Carol","StudentAge":21}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e5715e86fd1496b38c7") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":40,"StudentName":"Bob","StudentAge":20}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e6515e86fd1496b38c8") } >db.getDistinctWithSortedDataDemo.insertOne({"StudentId":40,"StudentName":"Bob","Stude ntAge":20}); { "acknowledged" : true, "insertedId" : ObjectId("5c9b1e6d15e86fd1496b38c9") }
다음은 find() 메서드를 사용하여 컬렉션의 모든 문서를 표시하는 쿼리입니다.
> db.getDistinctWithSortedDataDemo.find().pretty();
그러면 다음과 같은 출력이 생성됩니다.
{ "_id" : ObjectId("5c9b1e3315e86fd1496b38c3"), "StudentId" : 10, "StudentName" : "John", "StudentAge" : 23 } { "_id" : ObjectId("5c9b1e3e15e86fd1496b38c4"), "StudentId" : 20, "StudentName" : "Carol", "StudentAge" : 21 } { "_id" : ObjectId("5c9b1e4415e86fd1496b38c5"), "StudentId" : 10, "StudentName" : "John", "StudentAge" : 23 } { "_id" : ObjectId("5c9b1e5115e86fd1496b38c6"), "StudentId" : 30, "StudentName" : "Chris", "StudentAge" : 22 } { "_id" : ObjectId("5c9b1e5715e86fd1496b38c7"), "StudentId" : 20, "StudentName" : "Carol", "StudentAge" : 21 } { "_id" : ObjectId("5c9b1e6515e86fd1496b38c8"), "StudentId" : 40, "StudentName" : "Bob", "StudentAge" : 20 } { "_id" : ObjectId("5c9b1e6d15e86fd1496b38c9"), "StudentId" : 40, "StudentName" : "Bob", "StudentAge" : 20 }
다음은 "StudentName"에 대한 정렬된 데이터로 고유한 값을 가져오는 쿼리입니다.
> db.getDistinctWithSortedDataDemo.distinct("StudentName").sort();
그러면 다음과 같은 출력이 생성됩니다.
[ "Bob", "Carol", "Chris", "John" ]
다음은 StudentAge에 대한 정렬된 데이터로 고유한 값을 가져오는 쿼리입니다.
> db.getDistinctWithSortedDataDemo.distinct("StudentAge").sort();
그러면 다음과 같은 출력이 생성됩니다.
[ 20, 21, 22, 23 ]