• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

258
Views
Mongoose elimina otros objetos después de la actualización

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) } }
about 3 years ago · Juan Pablo Isaza
1 answers
Answer question

0

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 } );
about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error