我有一个包含字符串数组的mongo文档,我需要将此特定数组字符串转换为包含键值对的数组。以下是我对它的一些看法。将mongo数组转换为具有键值对的对象
{
"_id" : ObjectId("57e3720836e36f63695a2ef2"),
"platform" : "A1",
"available" : {
"Community" : {
"attributes" : {
"type" : {
"values" : [
"well-known",
"simple",
"complex"
],
"defaultValue" : "well-known"
},
[......]
}
当前查询:
templateAttributes.find({platform:"V1"}).map(function(c){
//instantiate a new array
var optionsArray = [];
for (var i=0;i< c['available']['Community']['attributes']['type']['values'].length; i++){
optionsArray[i] = {}; // creates a new object
optionsArray[i].label = c['available']['Community']['attributes']['type']['values'][i];
optionsArray[i].value = c['available']['Community']['attributes']['type']['values'][i];
}
return optionsArray;
})[0];
结果:
[{label:"well-known", value:"well-known"},
{label:"simple", value:"simple"},
{label:"complex", value:"complex"}]
是我的做法效率不够高,或者是有没有办法来优化上面的查询得到同样的期望的结果?
需要在MongoDB上做什么具体的原因? –
不。没有具体原因需要在mongo方面完成。由于我在流星中使用这个查询,所以这个查询在内存中运行(mini-mongo)。 – blueren
@bluereen好的。然后聚合是解决方案。请记住'$ unwind'会乘以结果集大小array.length times。因此,以前使用'$ project'只需保留必需的字段,也许只有'值'。 –