我收到了重复的密钥错误而不确定原因。
我有以下架构:
var walletSchema = mongoose.Schema({
currencyName : {type : String, required : true, unique : true},
amount : {type : Number, default : 0}
}, {strict : false});
// define the schema for our user model
var userSchema = mongoose.Schema({
local : {
username : { type: String, required: true, unique: true },
password : { type: String, required: true, unique : true },
email : { type: String, required: true, unique: true },
country : { type: String, required: true },
inventory : {
food : { type : Number, default : 0},
energyDrinks : { type : Number, default : 0 }
},
wallet : [walletSchema],
lastAttackedAt : { type: Date, default: Date.now },
lastJobChange : {type: Date, default: '03/30/1988' },
lastWorked : {type: Date},
referredBy : {type : String, default : 'Admin'},
energy : { type: Number, default: 100 },
energyUpdatedAt : { type : Date, default: Date.now },
resetPasswordToken: String,
resetPasswordExpires: Date
}
},{timestamps : true});
我使用以下代码创建了一个新用户:
...
newUser.local.username = capitalizeUser(username);
newUser.local.password = newUser.generateHash(password);
newUser.local.email = req.body.email;
newUser.local.country = req.body.country;
newUser.local.wallet.push({
// Create the default currencies
currencyName: 'Euro',
}, {
currencyName: 'Gold',
}, {
currencyName: result.countryCurrency
}
);
// save the user
newUser.save(function(err) {
if (err)
throw err;
return done(null, newUser);
});
对于第一个用户,一切正常,但如果我尝试创建另一个用户,我会得到MongoError: insertDocument :: caused by :: 11000 E11000 duplicate key error index: xyz.users.$local.wallet.currencyName_1 dup key: { : "Euro" }
。
为什么会发生这种情况,并不是每个用户都拥有自己的wallet
?我应该如何处理它,请记住,每个用户可以使用约230种货币。
答案 0 :(得分:1)
q){y+2*x}/[3;4 5 6]
56
从那里删除独特,你会很高兴。 Mongo检查用于收集的唯一密钥。在你的情况下,walletSchema集合将有很多相同的值,这就是它给出错误的原因。
答案 1 :(得分:0)
由于您的currencyName已设置为唯一,因此您保存的每个用户必须不同。实际上,使用此架构,您甚至无法拥有来自同一国家/地区的两个用户。
为避免这种情况,您需要从架构中删除唯一关键字并完成。它看起来像这样。
var walletSchema = mongoose.Schema({
currencyName : {type : String, required : true},
amount : {type : Number, default : 0}
}, {strict : false});