猫鼬重复密钥

时间:2016-08-02 13:54:29

标签: node.js mongodb mongoose

我收到了重复的密钥错误而不确定原因。

我有以下架构:

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种货币。

2 个答案:

答案 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});