【问题标题】:Node JS MongoDB Not Saving节点 JS MongoDB 不保存
【发布时间】:2016-02-13 07:58:59
【问题描述】:

我是 Node JS 的新手,所以我可能会遗漏一些相当明显的东西。我最近一直在尝试使用猫鼬将一些数据保存到数据库中,但我的尝试没有成功。虽然服务器告诉我它已保存,但我的数据库中没有数据的痕迹。

app.js(靠近底部的相关代码部分)

/* REQUIRES */
var express = require('express');
var mongoose = require('mongoose');
var bodyParser = require('body-parser');
var ejs = require('ejs');
var moment = require('moment');
var app = express();
var router = express.Router();
var port = 80;
moment().format();

/* MONGOOSE CONNECT & MODEL */
mongoose.connect('mongodb://127.0.0.1:27017/giveaway');
var Giveaway = require('./models/giveaway');
var Entry = require('./models/entry');

/* EXPRESS APP LISTEN */
app.listen(port, function() {
  console.log('Magic happens on port %s.', port);
});

/* VIEW ENGINE, MIDDLEWARE SETUP, AND STATIC FILES */
app.set('view engine', 'html');
app.engine('html', ejs.renderFile);
app.use(express.static(__dirname + '/public'));
app.use(bodyParser.urlencoded({ extended: false }));

router.get('/:giveawayId', function(req, res, next) {
  var giveawayId = req.params.giveawayId;
  Giveaway.find({ _id: giveawayId }, function(err, giveaway) {
    if (err) throw err;
    if (Object.keys(giveaway).length < 1) {
      /* NO GIVEAWAY WITH THAT TITLE */
      console.log("error");
      next();
    } else {
      res.render('pages/giveaway', { giveaway: giveaway });
    }
  });
});

router.post('/:giveawayId/enter', function(req, res, next) {
  var giveawayId = req.params.giveawayId;
  var name = req.body.name;
  var email = req.body.email;
  if (name !== "" && email !== "") {
    Entry.findOne({ email: email }, function(err, entry) {
      if (err) throw err;
      if (entry !== null) {
        /* ALREADY ENTERED */
        console.log("error");
        console.dir(entry);
        next();
      } else {
        console.log("success");
          var newEntry = new Entry({
            name: name,
            email: email,
            giveaway: giveawayId
          });
          newEntry.save(function(err) { //PROBLEM IS HERE WHERE IT SAVES THE DATA
            if (err) throw err;
            res.redirect('/' + giveawayId);
          });
      }
    });
  }
});

app.use('/', router);

entry.js(相关模型)

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

var entrySchema = new Schema({
  name: String,
  email: String,
  giveaway: String,
  dateEntered: Date,
  winner: {
    type: Boolean,
    'default': false
  }
});

entrySchema.pre('save', function(next) {
  if (!this.dateEntered) {
    this.dateEntered = new Date;
  }
  next();
});

var Entry = mongoose.model('Entry', entrySchema);
module.exports = Entry;

输入者被保存到数据库的app.js底部附近的代码是问题所在。我假设这是我忽略的某种异步错误,但所有帮助将不胜感激。另一条可能有用的信息是 entry 变量的输出。即使数据没有显示在数据库中,它也会显示为查询的结果。

error
model {
  '$__': 
   InternalCache {
     strictMode: true,
     selected: undefined,
     shardval: undefined,
     saveError: undefined,
     validationError: undefined,
     adhocPaths: undefined,
     removing: undefined,
     inserting: undefined,
     version: undefined,
     getters: {},
     _id: undefined,
     populate: undefined,
     populated: undefined,
     wasPopulated: false,
     scope: undefined,
     activePaths: StateMachine { paths: [Object], states: [Object], stateNames: [Object] },
     ownerDocument: undefined,
     fullPath: undefined,
     emitter: EventEmitter { domain: null, _events: {}, _eventsCount: 0, _maxListeners: 0 } },
  isNew: false,
  errors: undefined,
  _doc: 
   { __v: 0,
     giveaway: 'NyX2sanGx',
     email: 'test',
     name: 'test',
     dateEntered: Wed Nov 11 2015 19:13:50 GMT-0800 (PST),
     _id: ObjectID { _bsontype: 'ObjectID', id: 'VD\u0003î½åwÑ89ì' } },
  '$__original_save': { [Function] numAsyncPres: 1 },
  save: [Function: wrappedPointCut],
  _pres: { '$__original_save': [ [Object], [Object], [Object] ] },
  _posts: { '$__original_save': [] } }

谢谢, 卡梅伦·琼斯

编辑:只是为了确认一下,其他时间我保存数据时它显示在数据库中完全没有问题。它只是最后一个在起作用。

【问题讨论】:

  • 当你show collections时,入口模型是否出现?
  • 确实如此,但我如何将其放入赠品数据库? @乔丹

标签: javascript node.js mongodb debugging asynchronous


【解决方案1】:

让 Mongoose 暂时搁置一会,让我们先尝试在 Mongo 上进行建模。

您的目标是每个赠品允许 1 个电子邮件条目,因此您首先创建唯一索引:

db.entry.ensureIndex({email:1, giveaway:1}, {unique:true});

接下来,要以原子方式完成所有操作,您将使用upsert(更新或插入)

编辑:删除 $set 部分

db.entry.update({
    email: 'me@me.com',
    giveaway: 1
}, {
    $setOnInsert: {
        name: 'John',
        email: 'me@me.com',
        giveaway: 1,
        created: ISODate()
    }
}, {
    upsert: true
});

这意味着:尝试使用电子邮件me@me.com 和赠品1 查找用户,如果找不到,则使用名称、电子邮件、赠品、创建和修改日期创建新条目。

查看您的记录:

db.entry.findOne()

{
    "_id" : ObjectId("56441446e480d6b501bd0a93"),
    "created" : ISODate("2015-11-12T04:23:34.086Z"),
    "email" : "me@me.com",
    "giveaway" : 1,
    "name": "John"
}

Mongoose 支持 $setOnInsert

var options = {
    upsert: true,
    'new': true,
    setDefaultsOnInsert: true
};
var find = {
    email: 'me@me.com',
    giveaway: 1,
};
var setOnInsert = {
    email: 'me@me.com',
    giveaway: 1,
    name: 'John',
    created: new Date()
};
Entry.findOneAndUpdate(find, {$setOnInsert: setOnInsert}, options);

【讨论】:

  • 目标是仅在没有相同电子邮件的条目时才添加新条目。我要问的问题是为什么它不保存。此解决方案适用于您解释的内容,但与保存问题无关。注意:再说一次,我对 MongoDB 和 NodeJS 很陌生,所以我还没有研究过更简单的做事方法。
  • @CameronJones 将您的保存机制重写为我描述的那个,问题就消失了。
  • 见上文 - 稍作修改即可使用;
  • 一件事:我不想更新它。如果没有相同的电子邮件,我只想插入一个新的。由于我不完全擅长使用猫鼬,有没有办法可以删除更新功能而它仍然可以正确保存?非常感谢。 @jpaljasma
  • @CameronJones 见上文 - 您只需丢弃 $set 部分。完美运行。
猜你喜欢
  • 1970-01-01
  • 2019-01-21
  • 2014-08-30
  • 2018-06-15
  • 2018-06-02
  • 1970-01-01
  • 1970-01-01
  • 2017-12-03
  • 2021-11-12
相关资源
最近更新 更多