Załóżmy, że współrzędne w lewym dolnym rogu i w prawym górnym rogu są odpowiednio [0, 0]
i [100, 100]
. Z MongoDB 3.2 możesz użyć $slice
operatora, aby zwrócić podzbiór tablicy, który jest tym, czego chcesz.
db.collection.aggregate([
{ "$match": {
"loc": {
"$geoWithin": {
"$box": [
[0, 0],
[100, 100]
]
}
}}
}},
{ "$group": {
"_id": "$name",
"submitted": { "$max": "$submitted" },
"preview": { "$first": "$preview" }
"locs": { "$push": "$loc" }
}},
{ "$project": {
"locs": { "$slice": [ "$locs", 5 ] },
"preview": 1,
"submitted": 1
}},
{ "$limit": 10 }
])