MongoDB - Mongoose - 只能调用一次控制器保存方法。然后它再也不会保存

时间:2016-08-11 13:06:16

标签: javascript node.js mongodb mongoose

请参阅下面的编辑

我正在做的是通过发布请求调用控制器保存功能。当我第一次运行该方法时,似乎保存了我制作的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");
    });
}

Mongoose初始化:

var mongoose = require('mongoose');

//controllers
var poll = require('./controllers/poll.js');

//Mongostuff
mongoose.Promise = global.Promise;
mongoose.connect('localhost:27017/pollr');

mongod log:

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个小时来搜索解决方案,但它没有给我一个。这可能是我做过的愚蠢事,或者我忽视了一些事情。

谢谢!

编辑:

显然它正在保存,但不会在日志中记录它。如果我只知道哈哈。我能做点什么吗?

1 个答案:

答案 0 :(得分:1)

尝试使用以下方法同时创建多个文档。它使用一个数组来保存文档,然后将该数组传递给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以确保它们是唯一的。