猫鼬更新许多用法

时间:2020-03-10 02:27:58

标签: mongodb express mongoose mongoose-schema

我正在尝试从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上搜索了很多资源,但在这里找不到我的错误。

1 个答案:

答案 0 :(得分:0)

您将必须将req.user.id解析为ObjectID。你可以这样写 mongoose.Types.ObjectId(req.user.id);