猫鼬推向阵列

时间:2019-05-27 20:52:23

标签: node.js express mongoose

我需要将一个对象推入数据库的数组中,但出现错误。我究竟做错了什么 ?我找到了这样一个主题Push items into mongo array via mongoose,但无法正确应用 ................................................... ................................................... .....................

habalka.files.push({_id: "tata", destination: "Harry"});
    habalka.save((res) => {
      console.log(res)
    });

当我尝试这段代码时,我得到了这个答案

MongooseError:保存之前,文档必须具有_id

enter image description here enter image description here

数据库

{
 "_id": "78935e75-86c0-47c2-a76d-2b52a0a71e7c",
    "files": [
        {
            "_id": "67e848e5-7fb0-480b-a1d3-f3a09d1b57f7",
            "destination": "./uploads/78935e75-86c0-47c2-a76d-2b52a0a71e7c",
            "filename": "67e848e5-7fb0-480b-a1d3-f3a09d1b57f7.mp3",
            "path": "uploads\\78935e75-86c0-47c2-a76d-2b52a0a71e7c\\67e848e5-7fb0-480b-a1d3-f3a09d1b57f7.mp3",
            "folder": "78935e75-86c0-47c2-a76d-2b52a0a71e7c",
            "info": {
                "size": 12120000,
                "mimetype": "audio/mp3",
                "encoding": "7bit",
                "originalname": "Попрошайка Евгений Владимирович из ФАСП. Выпуск 10.mp3",
                "fieldname": "selectedFile"
            },
            "date": {
                "$date": "2019-05-23T01:07:27.122Z"
            }
        }
    ],
    "date": {
        "$date": "2019-05-23T01:07:27.123Z"
    },
    "__v": 0
}

模式

const mongoose = require('mongoose');
const Schema = mongoose.Schema;

const HabalkaSchema = new Schema({
  _id: {
    type: String
  },
  files: [
    {
      _id: {
        type: String
      },
      destination: {
        type: String
      },
      filename: {
        type: String
      },
      path: {
        type: String
      },
      folder: {
        type: String
      },
      info: {
        size: {
          type: Number
        },
        mimetype: {
          type: String
        },
        encoding: {
          type: String
        },
        originalname: {
          type: String
        },
        fieldname: {
          type: String
        },
      },
      date: {
        type: Date,
        default: Date.now
      }
    }
  ],
  date: {
    type: Date,
    default: Date.now
  }
});
module.exports = Habalka = mongoose.model('habalka', HabalkaSchema);

请求

let Habalka = habalka.findOne({_id: "78935e75-86c0-47c2-a76d-2b52a0a71e7c"});
Habalka.files.push({destination: "Harry"});
Habalka.save();

2 个答案:

答案 0 :(得分:0)

我相信您的问题应该在files时推送到目的地

我会尝试

habalka.update(
{_id: "78935e75-86c0-47c2-a76d-2b52a0a71e7c"},
{$push: { files: {destination: "Harry"} }
);

答案 1 :(得分:0)

我找到了这个解决方案和这项工作。

Habalka.findById("78935e75-86c0-47c2-a76d-2b52a0a71e7c")
  .then(post => {
    console.log(post)
    post.files.unshift({_id: "tata", destination: "vava"});
    post.save().then(res => console.log(res));
  })
  .catch(err => res.status(404).json({ postnotfound: 'No post found' }));