无法使用猫鼬更新 Mlab 文档的值,它被保存为“__v”:0

Not able to update values of an Mlab document using mongoose, it is getting saved as "__v": 0

我是 node 新手,mongoDb, 我有一个 mongo 数据库帐户,我在其中创建了一个名为 "dbTestData"

的集合

我正在尝试使用 node express mongoose 和 express 创建 CRUD 操作, 我正在使用 postman 获取 post 更新和删除 mlab 数据库的值。

我的 Get 调用工作正常,但是当我尝试 post Json 中的值时,

我收到成功消息,但是当我检查数据库时,它被保存为

{
    "_id": {
        "$oid": "5c3ad1c19bc5932f800d26f7"
    },
    "__v": 0
}

我的app.js

const express = require('express');

const bodyParser = require("body-parser");
const mongoose=require('mongoose');
const app = express();
const dbTestData=require('./models/post')
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));


mongoose.connect("mongodb://<userName>:<password>@ds221242.mlab.com:21242/kiitasklist").then(()=>{
  console.log("hello");
}).catch(
  ()=>{
    console.log("heee");
  });

app.use((req, res, next) => {
    res.setHeader("Access-Control-Allow-Origin", "*");
    res.setHeader(
      "Access-Control-Allow-Headers",
      "Origin, X-Requested-With, Content-Type, Accept"
    );
    res.setHeader(
      "Access-Control-Allow-Methods",
      "GET, POST, PATCH, PUT,DELETE, OPTIONS"
    );
    next();
  });

  app.post("/api/posts", (req, res, next) => {
    const post = new dbTestData({
      id:req.body.id,
      name:req.body.name
    });
    post.save().then(documents=>{
      console.log(post);
      res.status(201).json({
        message: 'Post added successfully'
      });
    });
  });


app.get("/api/posts",(req,res,next)=>{
  dbTestData.find().then(documents=>{
  res.status(200).json({
    message:'Posts fetched successful',
    posts:documents
    });
});
});


app.put("/api/posts/:id",(req,res,next)=>{
  const post = new dbTestData({
    _id:req.body._id,
    name:req.body.name
  });
  dbTestData.updateOne({_id:req.params.id},post).then(result=>{
    res.status(200).json({message:"update successfully"});
  });
});

app.delete("/api/posts/:id",(req,res,next)=>{
  dbTestData.deleteOne({_id:req.params.id}).then(documents=>{
     res.status(200).json({
       message:'posts fetched successful',
       posts:documents
     });
   });
});

module.exports = app;

我的Server.js

const http = require('http');
const app = require('./api/app');

const port = process.env.PORT || 3000;

const server = http.createServer(app);

server.listen(port);

我的 post.js 我在其中创建了 mongoose 架构

const mongoose=require('mongoose');

var Schema = mongoose.Schema; 
module.exports= mongoose.model("dbTestData", new Schema({}), "DbTestData"); 

获取和删除都有效, 但是 post 和 put 没有正常发生,它 returns 在我的控制台中是一条成功消息,但空值如

{
    "_id": {
        "$oid": "5c3ad1c19bc5932f800d26f7"
    },
    "__v": 0
}

在 POST 期间保存,在 PUT 期间没有任何反应。

解决这个post问题

var Schema = mongoose.Schema; 

PostSchema = new Schema({
 id:Number,
 name: String
});
// the compile the model using mongoos model function giving the schema u created
const Post = module.exports= mongoose.model("dbTestData", PostSchema, "DbTestData");

然后在你的 post 请求中这样做

//before posting you need to require the model first 
const Post = require('./models/post'); // your post.js
app.Post("/api/posts", (req, res, next) => {
    const post = new Post({
      id:req.body.id,
      name:req.body.name
    });
    post.save().then(documents=>{
      console.log(post);
      res.status(201).json({
        message: 'Post added successfully'
      });
    });
  });

确保 create/define 您的模式正确,以便使用它保存数据。 在那之后 put 和你做的一样,在你正确定义你的模式后它应该工作正常

最后也试试这个。确保你添加这些拖线的方式与我在你的情况下给出的完全相同,你已经切换了它们

// Body Parser Middleware
app.use(bodyParser.urlencoded({ extended: false }));
app.use(bodyParser.json());