我试图找出如何在不是索引的字段上强制执行唯一。
我在这里看到过类似的问题,但是使用dropDups:true的答案被提到要删除。
在字段上强制执行唯一的正确方法是什么?
const users = new Schema({
email: { type: String, required: true , unique: true},
...});
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);
如果你这样做,它将无法用于唯一密钥验证。
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
});