0

マージしたい 2 つのコレクションがあります。mapReduce は少しやり過ぎだと感じたので、次のようなことを試しました。

// 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オブジェクトで使用できるようにするにはどうすればよいですか?

4

1 に答える 1

0

あ、わかりました。[] 構文はもちろん機能します。

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 } );
            }
        }
    });
  }
);
于 2013-09-05T12:23:32.107 に答える