Tengo problemas con mi consulta de actualización en mongoose. No estoy seguro de por qué se eliminan otros objetos después de actualizar un objeto específico. el código funciona cuando actualizo, pero después de eso, el resto de los objetos dentro de la matriz se eliminan/eliminan. Literalmente, todos los objetos restantes se eliminan después de la solicitud de actualización.
export const updateProduct = async (req,res) => { const { id } = req.params; try { if(!mongoose.Types.ObjectId.isValid(id)) return res.status(404).json({ message: 'Invalid ID' }); await OwnerModels.findOneAndUpdate({'_id': id, store:{$elemMatch: {productname: req.body.store[0].productname }}}, {$set: { store: { productname: req.body.store[0].productname, price: req.body.store[0].price, quantity: req.body.store[0].quantity, categoryfilter: req.body.store[0].categoryfilter, description: req.body.store[0].description, timestamp: req.body.store[0].timestamp } } }, // list fields you like to change {'new': true, 'safe': true, 'upsert': true}); } catch (error) { res.status(404).json(error) } }
No estoy seguro de por qué se eliminan otros objetos después de actualizar un objeto específico.
Debido a que está actualizando todo el objeto y reemplazará la matriz de almacenamiento de objetos existente en la base de datos,
Debe usar arraFilters, y upsert
no es efectivo en la matriz de objetos actualizados, por lo que he comentado,
await OwnerModels.findOneAndUpdate( { '_id': id, store:{ $elemMatch: { productname: req.body.store[0].productname } } }, { $set: { store: { "store.$[s].productname": req.body.store[0].productname, "store.$[s].price": req.body.store[0].price, "store.$[s].quantity": req.body.store[0].quantity, "store.$[s].categoryfilter": req.body.store[0].categoryfilter, "store.$[s].description": req.body.store[0].description, "store.$[s].timestamp": req.body.store[0].timestamp } } }, { 'arrayFilters': [ { "s.productname": req.body.store[0].productname } ], 'new': true, 'safe': true, // 'upsert': true } );