Computer >> 컴퓨터 >  >> 프로그램 작성 >> MongoDB

MongoDB 쿼리에서 배열을 정렬하고 모든 필드를 투영하시겠습니까?

<시간/>

배열을 정렬하려면 $sort를 사용하십시오. 프로젝션의 경우 MongoBD 집계()에서 $project를 사용합니다. 문서로 컬렉션을 만들자 −

> db.demo252.insertOne(
...   {"Values" : [ { "v1" : 20, "v2" :30 }, { "v1" : 20, "v2" : 20 }, { "v1" : 10, "v2" : 7 } ] }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e46c2761627c0c63e7dba78")
}

find() 메서드를 사용하여 컬렉션의 모든 문서 표시 -

> db.demo252.find();

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : ObjectId("5e46c2761627c0c63e7dba78"), "Values" : [ { "v1" : 20, "v2" : 30 }, { "v1" : 20, "v2" : 20 }, { "v1" : 10, "v2" : 7 } ] }

다음은 배열을 정렬하고 집계() −

를 사용하여 모든 필드를 투영하는 쿼리입니다.
> db.demo252.aggregate([
...   { "$unwind": "$Values"},
...   { "$sort": {"Values.v2":1, "Values.v1": 1}},
...   { "$group": {
...      "_id": {
...         "_id": "$_id"
...
...      },
...      "st": { "$push":"$Values"}
...   }},
...   { "$project": {
...      "_id": "$_id._id",
...      "Values": "$st"
...   }}
...]);

이것은 다음과 같은 출력을 생성합니다 -

{ "_id" : ObjectId("5e46c2761627c0c63e7dba78"), "Values" : [ { "v1" : 10, "v2" : 7 }, { "v1" : 20, "v2" : 20 }, { "v1" : 20, "v2" : 30 } ] }