MongoDB - Mongoose -只能调用一次控制器的save方法.然后它就再也不存钱了

MongoDB - Mongoose - Can only call the controllers save method once. Then it never saves again

本文关键字:然后 方法 save 再也不 控制器 一次 -只 Mongoose 调用 MongoDB      更新时间:2023-09-26

请参见下面的编辑

我正在做的是通过post请求调用控制器保存函数。当我第一次运行该方法时,它似乎保存了我制作的2个对象。然后它会把我引到正确的路线上。但是当我回去张贴相同的post请求。它给我console.log的,但从来没有真正保存它们。

路由器:

app.post('/new', function(req, res, next){
  poll.newPoll(req, res, next);
  next();
}, function(req, res){
  res.redirect('/ok');
})

模式:

var mongoose = require('mongoose');
var Schema = mongoose.Schema;
//Schema for the polls
var pollSchema = new Schema({
  title: String,
  hash: String
});
var Poll = mongoose.model('Poll', pollSchema);
module.exports = Poll;

和控制器:

var Poll = require('../modules/poll.js');
var hash = require('randomstring');
var randomHash = hash.generate({
  length: 5
});
//Function for creating new polls
module.exports.newPoll = function(req, res, next){
    var createdPoll = new Poll({title: "Wazap", hash: randomHash});
    var secondPoll = new Poll({title: "Ok", hash: randomHash});
    createdPoll.save(function (err, createdPoll) {
      if (err) {
        console.log(err);
        return handleError(err);
      }
      console.log("New Poll saved");
    });
    secondPoll.save(function (err, secondPoll) {
      if (err) {
        console.log(err);
        return handleError(err);
      }
      console.log("New Poll saved");
    });
}

猫鼬初始化:

var mongoose = require('mongoose');
//controllers
var poll = require('./controllers/poll.js');
//Mongostuff
mongoose.Promise = global.Promise;
mongoose.connect('localhost:27017/pollr');

mongod日志:

2016-08-11T14:51:38.142+0200 I COMMAND  [conn3] command pollr.polls command: insert { insert: "polls", documents: [ { title: "Wazap", hash: "pxeZP", _id: ObjectId('57ac74d997df31a423f20049'), __v: 0 } ], ordered: false, writeConcern: { w: 1 } } ninserted:1 keyUpdates:0 writeConflicts:0 numYields:0 reslen:40 locks:{ Global: { acquireCount: { r: 2, w: 2 } }, Database: { acquireCount: { w: 1, W: 1 } }, Collection: { acquireCount: { W: 1 } } } protocol:op_query 197ms
2016-08-11T14:51:38.143+0200 I COMMAND  [conn4] command pollr.polls command: insert { insert: "polls", documents: [ { title: "Ok", hash: "pxeZP", _id: ObjectId('57ac74d997df31a423f2004a'), __v: 0 } ], ordered: false, writeConcern: { w: 1 } } ninserted:1 keyUpdates:0 writeConflicts:0 numYields:0 reslen:40 locks:{ Global: { acquireCount: { r: 1, w: 1 } }, Database: { acquireCount: { w: 1 }, acquireWaitCount: { w: 1 }, timeAcquiringMicros: { w: 143945 } }, Collection: { acquireCount: { w: 1 } } } p

只有当我删除数据库中的所有数据时,它才能再次保存。我希望这是足够的信息给。我在谷歌上搜索了2个多小时来寻找解决方案,但它没有给我一个。这可能是我做了什么蠢事,或者我忽略了什么。

谢谢!


编辑:

显然它正在保存,但没有在日志中记录它。要是我知道就好了,哈哈。我能做点什么吗?

尝试使用以下方法同时创建多个文档。它使用一个数组来保存文档,然后将该数组传递给create方法,该方法有一个回调函数,可用于调用错误或对结果保存的文档做一些事情。

//Function for creating new polls
module.exports.newPoll = function(req, res, next){
    var docs = [{title: "Wazap", hash: randomHash}, {title: "Ok", hash: randomHash}];
    Poll.create(docs, function (err, wazap, ok) {
        if (err) {
            console.log(err);
            return handleError(err);
        }
        console.log("Saved Wazap :" + wazap + " Saved Ok: " + ok)
    });
}

我已经将保存的文档添加到console.log中,这样您就可以检查它们的_id,以确保它们是唯一的。

相关文章: