[mongodb]如何保存文件并自动增加一个字段?

时间:2017-12-18 23:51:52

标签: mongodb mongoose

我需要在我的mongo数据库中保存或插入新记录。我希望它的字段“userid”可以自动增加1.是否可以在mongodb中进行?

Schema
generalUserApplication: {
    userid: Number, // 1
    lora: [
       {},
       {}
    ]
}

2 个答案:

答案 0 :(得分:0)

这是mongo教程的方式。

您需要在数据库中创建新的集合counters

function getNextSequence(db, name, callback) {
    db.collection("counters").findAndModify( { _id: name }, null, { $inc: { seq: 1 } }, function(err, result){
        if(err) callback(err, result);
        callback(err, result.value.seq);
    } );
}

然后,当您插入新行时,可以使用getNextSequence(),如下所示。

getNextSequence(db, "user_id", function(err, result){
    if(!err){
        db.collection('users').insert({
            "_id": result,
            // ...
        });
    }
});

答案 1 :(得分:0)

我使用了另一个名为' mongoose-sequence-plugin '生成自动递增1的序列。 在这里,我发布了我为同样的问题尝试过的代码。希望它会有所帮助。

架构:

var mongoose     = require('mongoose');
var sequenceGenerator = require('mongoose-sequence-plugin');
var Schema       = mongoose.Schema;

var ProjectSchema   = new Schema({
    Name : { type : String, required: true },
    Description : { type : String, required: true },
    DetailAddress : { type : String, required: true },
    ShortAddress : { type : String, required: true },
    Latitude : { type : Number, required: true },
    Longitude : { type : Number, required: true },
    PriceMin : { type : Number, required: true, index : true },
    PriceMax : { type : Number, required: true, index: true },
    Area : { type : Number, required: true },
    City : { type : String, required: true }
});

ProjectSchema.plugin(sequenceGenerator, {
    field: 'project_id',
    startAt: '10000001',
    prefix: 'PROJ',
    maxSaveRetries: 2
});

module.exports = mongoose.model('Project', ProjectSchema);

这将从 PROJ10000001 和病房开始创建参数 project_id 的项目集合。如果删除最后插入的记录,则此包将读取字段project_id的当前最后一个条目,并通过递增当前id来分配下一个id。