要选择两个字段并返回具有不同值的排序数组,请使用聚合框架和 $setUnion 运算符。让我们首先创建一个包含文档的集合 -
> db.sortedArrayWithDistinctDemo.insertOne( ... { value1: 4, value2: 5} ... ); { "acknowledged" : true, "insertedId" : ObjectId("5cc690b99cb58ca2b005e666") } > db.sortedArrayWithDistinctDemo.insertOne( ... {value1: 5, value2: 6} ... ); { "acknowledged" : true, "insertedId" : ObjectId("5cc690b99cb58ca2b005e667") } > db.sortedArrayWithDistinctDemo.insertOne( ... {value1: 7, value2: 4} ... ); { "acknowledged" : true, "insertedId" : ObjectId("5cc690b99cb58ca2b005e668") }
以下是在find()方法的帮助下显示集合中所有文档的查询-
> db.sortedArrayWithDistinctDemo.find().pretty();
这将产生以下输出 -
{ "_id" : ObjectId("5cc690b99cb58ca2b005e666"), "value1" : 4, "value2" : 5 } { "_id" : ObjectId("5cc690b99cb58ca2b005e667"), "value1" : 5, "value2" : 6 } { "_id" : ObjectId("5cc690b99cb58ca2b005e668"), "value1" : 7, "value2" : 4 }
以下是选择两个字段并返回具有不同值的排序数组的查询。这里的字段是“value1”和“value2” -
> db.sortedArrayWithDistinctDemo.aggregate( ... [ ... { "$group": { ... "_id": null, ... "value1": { "$push": "$value1" }, ... "value2": { "$push": "$value2" } ... }}, ... { "$project": { ... "_id": 0, ... "bothValues": { "$setUnion": [ "$value1", "$value2" ] } ... }} ... ] ... );
这将产生以下输出。现在排序的数组返回不同的值 -
{ "bothValues" : [ 4, 5, 6, 7 ] }