[英]Merge two collections in mongodb without mapReduce…?
我有两个要合并的集合。 mapReduce感觉有点矫kill过正,所以我尝试了如下操作:
// setup
use testdb
db.users.remove();
db.profiles.remove();
db.users.save({email: "foo@bar.com", a: "a"});
db.profiles.save({email: "foo@bar.com", b: "b"});
// merge it
db.users.find().forEach(
function(user) {
print("updating user " + user.email);
db.profiles.find({email: user.email}).forEach(function(profile) {
for(field in profile) {
if(profile.hasOwnProperty(field) && !(field in user)) {
db.users.update( {_id: user._id}, { $set : { field : profile[field] } } );
}
}
});
}
);
db.users.find().pretty();
当然,这是无效的,因为不评估“字段”,而仅评估json字段名称。 我想做更新而不是保存。 我很讨厌js,所以我的问题是:如何评估字段名称,以便可以在$ set需要的json对象中使用它?
喔好吧。 []语法当然有效:
db.users.find().forEach(
function(user) {
print("updating user " + user.email);
db.profiles.find({email: user.email}).forEach(function(profile) {
for(field in profile) {
if(profile.hasOwnProperty(field) && !(field in user)) {
var setObj = {};
setObj[field] = profile[field];
db.users.update( {_id: user._id}, { $set : setObj } );
}
}
});
}
);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.