我正在尝试从mongoDB文档中更新多个值。
我正在使用ExpressJS和Mongoose。
我相信要更新多个值,我应该使用updateMany()。
但是,它一直给我这样的错误消息:
“在模型“订单”的路径“ _id”处,对值“ status”的值对ObjectId的投射失败”
为了给您提供详细信息,这是下面的代码:
订单模型
const mongoose = require('mongoose');
const OrderSchema = mongoose.Schema({
user: {
type: mongoose.Schema.Types.ObjectId,
ref: 'users',
required: true
},
menus: {
type: mongoose.Schema.Types.ObjectId,
ref: 'menus',
required: true
},
date: {
type: Date,
default: Date.now
},
status: {
type: String,
default: 'pending'
}
});
module.exports = mongoose.model('order', OrderSchema);
另外,这是我的ExpressJS代码:
const express = require('express');
const router = express.Router();
const Order = require('../models/Order');
const User = require('../models/User');
// @route PUT api/orders/status
// @desc Update All Order status
// @access Private
router.put('/status', auth, async (req, res) => {
const { status } = req.body;
const orderFields = {};
if (status) orderFields.status = status;
try {
const orders = await Order.updateMany(
{ user: req.user.id },
{ $set: orderFields }
);
if (!orders || orders.length === 0)
return res.status(404).json({ msg: 'Order not found!' });
res.json(orders);
} catch (err) {
console.error(err);
res.status(500).json({ error: err.message });
}
});
你们知道我错过了什么吗?
我已经检查过猫鼬API并在Google上搜索了很多资源,但在这里找不到我的错误。
答案 0 :(得分:0)
您将必须将req.user.id
解析为ObjectID。你可以这样写
mongoose.Types.ObjectId(req.user.id);