Say we have the following docs:
{a: 1, b: 2},
{a: 2, b: 0},
{a: 3, b: 1}
I want a query that will return:
[0, 1, 2, 3]
You could use something like that
db.getCollection('yourdocs').aggregate([
{
$project: {
values: [ "$a", "$b" ]
}
},
{
$unwind: "$values"
},
{
$group: {
_id: "distinctValues",
values: {
$addToSet: "$values"
}
}
}
])
which will result in
{
"_id" : "distinctValues",
"values" : [
0,
1,
2,
3
]
}
Update: Just read you want it sorted which is not guaranteed with $addToSet
. If sorting is crucial for you just add the following to the aggregation pipeline after the stages above
{
"$unwind": "$values"
},
{
"$sort": {
"values": 1
}
},
{
"$group": {
_id: "distinctValues",
"values": {
"$push": "$values"
}
}
}