我需要在我的mongo数据库中保存或插入新记录。我希望它的字段“userid”可以自动增加1.是否可以在mongodb中进行?
Schema
generalUserApplication: {
userid: Number, // 1
lora: [
{},
{}
]
}
答案 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。