0

例如,假设我有一个用户模式,并且我想在尝试将用户保存到数据库之前验证用户名是否唯一。

...

UserSchema.path('username')
  .validate(function (value, respond) {
    User.findOne({ username: this.username }) // This isn't valid.
      .lean()
      .select('_id')
      .exec(function (err, user) {

        if (err) {
          winston.warn('User_username: Error looking for duplicate users');
          respond(false);
        }

        // If a user was returned, then the user is non-unique!
        if (user) {
          respond(false);
        }

        respond(true);
      });
  });

...

var User = mongoose.model('User', UserSchema);

我知道我可以使用mongoose.model('User').findOne(...),但这似乎有点傻,没有更好的方法吗?

4

1 回答 1

1

您可以通过设置在架构中创建唯一索引unique: true。这将利用 mongodb 中可用的唯一索引选项。这是我使用此选项的模型之一的示例片段:

// The (generated) uniform resource locator
url: {
    // ... which is required ...
    required: true,
    // ... which is an unique index ...
    unique: true,
    // ... and is a string.
    type: String
}

来自评论的复合键:

Schema.index({ username: 1, accountCode: 1 }, { unique: true })
于 2013-03-04T11:20:47.317 回答