当MongoDB上的唯一索引失败时生成替代方案

时间:2013-07-20 01:20:06

标签: node.js mongodb oauth coffeescript

因此,当用户通过Google,Twitter等注册时,名称可能会重叠。在我的应用程序中,用户名具有唯一索引。由于每当有人第一次登录时都会将新文档放入集合中,因此有时唯一索引会失败。注册用户的代码如下:

module.exports.findOrCreateUser = (provider, id, data, done) ->
    User.findByAuth provider, id, (err, user) ->
        if err? then done err
        else if user? then done null, user
        else
            user = new User
                auth: [{id: id, provider: provider}]
                name: data.name
                email: data.email
            user.save (err) ->
                if err? then done err else done null, user

所以我在这里有两个问题:

  1. 如何检查err是否为唯一索引错误?
  2. 将唯一后缀附加到用户名称的最有效方法是什么?

1 个答案:

答案 0 :(得分:2)

  1. err对象的message属性与mongo shell提供的错误消息相匹配。检查是否存在唯一索引错误应该如下所示:

    if (err && err.message.indexOf('E11000 ') !== -1) {
        // this _id was already inserted in the database
    }
    
  2. 我同意@innoSPG将服务名称附加到用户名。如果您不希望指示与用户名关联的服务,只需在用户名后附加一个计数器,并在每次使用时递增。