我正在尝试找出如何在不是索引的字段上强制执行唯一。
我在这里看到了类似的问题,但是提到使用 dropDups:true 的答案将被删除。
在字段上强制执行唯一的正确方法是什么?
const users = new Schema({
email: { type: String, required: true , unique: true},
...});
答案 0 :(得分:1)
var mongoose = require('mongoose');
var uniqueValidator = require('mongoose-unique-validator');
// Define your schema as normal.
var userSchema = mongoose.Schema({
username: { type: String, required: true, unique: true },
email: { type: String, index: true, unique: true, required: true },
password: { type: String, required: true }
});
// Apply the uniqueValidator plugin to userSchema.
userSchema.plugin(uniqueValidator);
答案 1 :(得分:0)
如果你这样做,它将无法用于唯一密钥验证。
var userSchema = new Schema({
name : String,
username : {
type : String,
required : true,
index : {
unique : true,
dropDups : true
}
});
所以你现在就以正确和最好的方式做到这一点,就这样做
使用以下命令从数据库中删除集合
> db.<collection name>.drop()
然后重新启动服务器并以这种方式进行检查。
var userSchema = new Schema({
name : String,
username : {
type : String,
required : true,
unique : true
});