sql >> Databáze >  >> NoSQL >> MongoDB

Funkce pro výměnu hodnot v NodeJS s mongo+mongoose

Z Dokumentace Mongo UpdateOne UpdateOne používá 3 filtr argumentů ,aktualizovat ,zpětné volání , takže věřím, že musíte předat _id kolekce ke změně.

Update- find() vrátí kurzor a pro použití foreach jej převede na pole pomocí find().toArray().then(..so on)

// @route   PATCH api/swap
// @desc    replace date
// @access  Public

router.put("/swap", (req, res) => {
const firstDate = req.body.firstDate;
const secondDate = req.body.secondDate;

console.log(firstDate, secondDate);

Card.find().toArray().then(cards=>cards.forEach(card => {
    if (card.date === firstDate) {
      return card.updateOne( { date: firstDate } ,{ $set: { date: secondDate } });
    } else if (card.date === secondDate) {
      return card.updateOne( { date: secondDate },{ $set: { date: firstDate } });
    } else {
      return card;
    }
  });
}))
.then(() => console.log("working"));
 });



  1. Jak používat operaci $cond v agregačním rámci Spring-MongoDb

  2. Přeložte Queryable<T> zpět do IMongoQuery

  3. Redis/Jedis - Smazat podle vzoru?

  4. Upsert Dictionary v MongoDb