MongoDB
 sql >> Database >  >> NoSQL >> MongoDB

Come si aggiornano i criteri di corrispondenza degli elementi array in un documento MongoDB?

Da mongodb shell puoi farlo con

db.your_collection.update(
    { _id: ObjectId("your_objectid"), "Statuses.Type": 1 },
    { $set: { "Statuses.$.Timestamp": "new timestamp" } }
)

quindi l'equivalente in c#

var query = Query.And(
    Query.EQ("_id", "your_doc_id"),
    Query.EQ("Statuses.Type", 1)
);

var result = your_collection.Update( 
    query, 
    Update.Set("Statuses.$.Timestamp", "new timestamp", UpdateFlags.Multi,SafeMode.True)
); 

Questo aggiornerà il documento specifico, puoi rimuovere il filtro _id se desideri aggiornare l'intera raccolta