MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

não pode atualizar um documento via 'findById' e salvar () com promessa


Consideraria dividir a operação em partes gerenciáveis. Nesse caso, você deseja atualizar o showTakenSeats campo com os dados das posições do ticket do novo pedido.

Em primeiro lugar, usando o async await com sua rota expressa, você precisa salvar o pedido e obter o documento do pedido criado. Crie um documento com as novas vagas e atualize o documento show usando findByIdAndUpdate método.

O exemplo a seguir descreve o acima:
const express = require('express');
const router = express.Router();

const Order = require('../models/order.js');
const Show = require('../models/show.js');

router.post('/', async (req, res, next) => {
    try {
        /* create a new Order */
        const order = new Order(req.body);
        const newOrder = await order.save();

        /* create a document to use in the update with the following data structure:
            {
                'showTakenSeats.6-0': 5b53735ef7ce3d2cd4bbfee7,
                'showTakenSeats.6-1': 5b53735ef7ce3d2cd4bbfee7,
                'showTakenSeats.6-2': 5b53735ef7ce3d2cd4bbfee7 
            }

            Use the native reduce method on the array to create this 
        */
        const updatedSeats = newOrder.ticketPositions.reduce((acc, position) => {
            acc[`showTakenSeats.${position.join('-')}`] = newOrder._id;
            return acc;
        }, {});

        /* update the show document's embedded showTakenSeats 
           with the new properties from above 
        */
        const updateShow = await Show.findByIdAndUpdate(req.body._ShowId,
            { '$set': updatedSeats },
            { 'new': true }
        );

        res.json(updateShow);

    } catch (e) {
        /* this will eventually be handled by your error handling middleware */
        next(e);
    }
});