【问题标题】:Mongodb & Mongoose not creating unique indexMongodb 和 Mongoose 没有创建唯一索引
【发布时间】:2014-07-01 19:59:24
【问题描述】:

我在互联网上进行了广泛搜索,但似乎没有人对此问题有答案。我有一个与 Mongo 中的数据库相关联的 Mongoose 模式。我想在我的用户文档的电子邮件字段上创建一个唯一索引。从我能找到的有限文档中可以看出,下面的代码应该可以工作。谁能告诉我为什么会失败,并允许我创建具有重复电子邮件的用户?

var userSchema = new Schema({
    email: { type: String, required: true, index: { unique: true, trim: true } },
    password: String,
    firstName: String,
    lastName: String
 }, { autoIndex: true });

【问题讨论】:

  • 你能在命令行上使用 mongo 进入 mongodb 并检查索引(如果存在的话)是什么样子并将其添加到你的问题中吗?

标签: node.js mongodb mongoose


【解决方案1】:

trim 可能不应该存在:它是字符串的设置,而不是索引的设置。请尝试以下操作:

var userSchema = new Schema({
    email: { 
        type: String,
        trim: true,
        required: true,
        unique: true
    },
    password: String,
    firstName: String,
    lastName: String
}, { autoIndex: true });

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2014-08-08
    • 2011-08-21
    • 2016-11-19
    • 2014-09-01
    • 2018-09-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多