选择两个字段并在 MongoDB 中返回一个具有不同值的排序数组?
要选择两个字段并返回具有不同值的排序数组,请使用聚合框架和$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 ] }