sql >> データベース >  >> NoSQL >> MongoDB

MongoDBのすべてのドキュメントのフィールドの名前を変更するにはどうすればよいですか?

    使用できるもの:

    db.foo.update({}, {$rename:{"name.additional":"name.last"}}, false, true);
    

    または、プロパティを含むドキュメントを更新するには:

    db.foo.update({"name.additional": {$exists: true}}, {$rename:{"name.additional":"name.last"}}, false, true);
    

    false, true 上記の方法では、次のようになります。{ upsert:false, multi:true }multi:trueが必要です すべてを更新するには あなたの記録。

    または、前者の方法を使用できます:

    remap = function (x) {
      if (x.additional){
        db.foo.update({_id:x._id}, {$set:{"name.last":x.name.additional}, $unset:{"name.additional":1}});
      }
    }
    
    db.foo.find().forEach(remap);
    

    MongoDB3.2では使用することもできます

    db.students.updateMany( {}, { $rename: { "oldname": "newname" } } )
    

    これの一般的な構文は次のとおりです

    db.collection.updateMany(filter, update, options)
    

    https://docs.mongodb.com/manual/reference/method/db.collection.updateMany/



    1. Laravel:Redis接続できませんでした:[tcp://127.0.0.1:6379]

    2. なぜMongodbのパフォーマンスがWindowsよりもLinuxの方が優れているのですか?

    3. ネストされた配列データのelemMatchを使用したMongoDBクエリ

    4. 流星アプリのmongodbに2列の一意のIDを追加するにはどうすればよいですか?