猫鼬和Express-FindbyIdandUpdate覆盖第一个数组的值

时间:2020-05-09 13:42:38

标签: javascript mongodb express mongoose

我正在创建像快餐在线服务那样订购食物(我只是在练习)。现在让我感到困扰的是,我已经成功地创建了一个订单,当顾客来做饭时。选择另一餐后,order.id将更新订单,并使用$ push将另一餐添加到同一订单中。我遇到的问题是,添加第二餐时第一次创建订单时,第一餐被findbyIdAndUpdate覆盖。在添加第三餐之后,我从第二餐和第三餐中获得了数据,但是第一餐不存在。我正在使用MongoDB。有人可以告诉我如何解决这个问题吗?

很抱歉记录日志,并可能预先输入了错误的代码!

订购模式在这里:

var mongoose = require("mongoose");

var orderSchema = new mongoose.Schema({
    order: [{
        meal: {
            type: mongoose.Schema.Types.ObjectId,
            ref: 'Menu'
        },
        quantity: String
    }],
    user: {
        type: mongoose.Schema.Types.ObjectId,
        ref: "User",

    }



});

module.exports = mongoose.model("Order", orderSchema);

快速路线在这里:

app.post("/menu/order", middlewareObject.isLoggedin, function (req, res) {
    let order = {
        user: req.user._id,
        meal: req.body.foodID,
        quantity: req.body.quantity,

    }
    if (app.locals.orderID !== undefined) {
        order._id = app.locals.orderID;
        console.log(order._id);
        Order.findByIdAndUpdate(order._id, {
            $push: {
                order: {
                    meal: order.meal,
                    quantity: order.quantity,

                }
            }
        }, function (err, updated) {
            if (err) {
                console.log(err);
            } else {
                console.log("UPDATED!")
                res.redirect("back");
            }
        })
    } else {
        Order.create(order, function (err, newOrder) {
            if (err) {
                console.log(err)
            } else {
                console.log("CREATED!")
                app.locals.orderID = newOrder._id;
                res.redirect("back");
            }
        })
    }

})

Create()数据:

{ "_id" : ObjectId("5eb6b78bd336a7324c63621c"), "user" : ObjectId("5eb6b788d336a7324c63621a"), "order" : [ ], "__v" : 0 }

FindByUpdateandID数据:

{ "_id" : ObjectId("5eb6ba776d8684455cb8ece5"), "user" : ObjectId("5eb6b788d336a7324c63621a"), "order" : [ { "_id" : ObjectId("5eb6ba7d6d8684455cb8ece6"), "meal" : ObjectId("5eb6ba6a6d8684455cb8ecd7"), "quantity" : "5" }, { "_id" : ObjectId("5eb6ba7f6d8684455cb8ece7"), "meal" : ObjectId("5eb6ba6a6d8684455cb8ecd8"), "quantity" : "2" } ], "__v" : 0 }

0 个答案:

没有答案