Si desidera controllare la documentazione per l'aggiornamento.
http://www.mongodb. org/display/DOCS/Aggiornamento
Il tuo codice potrebbe essere simile a:db.tbl.update( { c:{$ne:0}}, { $set: { a : b } } );
Se hai bisogno di rispolverare query avanzate (ad esempio usando $ne
), quindi controlla qui:
http://www.mongodb.org /display/DOCS/Query+avanzate
EDIT:
Apparentemente non puoi aggiornare con i dati dello stesso documento.
MongoDB:aggiornamento di documenti utilizzando i dati dello stesso documento
EDIT 2 (soluzione con riduzione mappa) :
var c = new Mongo();
var db = c.getDB('db')
var s = db.getCollection('s')
s.drop();
s.save({z:1,q:5});
s.save({z:11,q:55});
db.runCommand({
mapreduce:'s',
map:function(){
var i = this._id; //we will emit with a unique key. _id in this case
this._id=undefined; //strange things happen with merge if you leave the id in
//update your document with access to all fields!
this.z=this.q;
emit(i,this);
},
query:{z:1}, //apply to only certain documents
out:{merge:'s'} //results get merged (overwrite themselves in collection)
});
//now take a look
s.find();