Node.js - 如何使用mongoose db创建唯一的id

时间:2012-06-29 17:11:32

标签: node.js mongodb mongoose

我正在使用Twitter身份验证,并希望将twitter ID存储为mongodb中的唯一键。但是,我看到具有相同ID的多个条目。这是我的架构和代码

架构:

var TwitterSchema = new Schema({
    accessToken: String,
    accessTokenSecret: String,
    name: String,
    twitterId: { type: String, required: true, index: { unique: true, sparse: true } }
});

代码:

        mongoose.connect('mongodb://localhost/twd')
        mongoose.model('Post', TwitterSchema);    
        var Post = mongoose.model('Post');

        var post = new Post();
        post.accessToken = accessToken
        post.accessTokenSecret = accessTokenSecret
        post.name = twitterUserData.name
        post.twitterId = twitterUserData.id

        post.save(function(err){
            if (err){
                throw err;
                promise.fail(err);
             }
            console.log('saved');
            mongoose.disconnect();
        });

        promise.fulfill(post);

DB shell输出

> db.posts.find();
{ "twitterId" : "21475255", "name" : "MMMK", "accessTokenSecret" : "ZYhiXMWfXvSr1aaCB93hgU243j8aapP0ALdSFlWEE", "accessToken" : "22475255-9YvKMceUInUIxcEtKAK0oMRRG2ZZxn5c52vnwPw", "_id" : ObjectId("4feddf6155203990e000001") }
{ "twitterId" : "21475255", "name" : "MMMK, "accessTokenSecret" : "ZYhiXMWfXvSr1aaCB93hgU2438aapP0ALdSFlWEE", "accessToken" : "22475255-9YvKMceUInUIxcEtKAK0oMRRG2ZZxn5c52vnwPw", "_id" : ObjectId("4feddf7b5905a1a10e000001") }

1 个答案:

答案 0 :(得分:1)

我的猜测是,未在MongoDB中创建索引,或者已经退出具有相同名称的索引。如果它已经存在,mongoose将使用ensureIndex来创建它,但如果它已经存在则不会覆盖/重新定义它。使用mongo js shell查看它是否存在,然后尝试删除它,重新启动mongod,再次运行node.js代码。

http://www.mongodb.org/display/DOCS/Indexes#Indexes-CreationOptions