您的位置:首页 > 产品设计 > UI/UE

mongoose设置unique不生效问题解决

2017-11-05 19:23 369 查看
1.unique属于schema约束验证中的一员,他的作用主要就是让某一个字段的值具有唯一性(不能重复)

2.保持字段的唯一性使用type值:{type:String,unique:true,dropDups: true}

3.mongoose一旦修改了数据存储的机构,数据库一定要重启,很多新手在设置一些属性不生效时都是这个原因

这里说的重启,不是简单的关闭mongoose数据库服务器重新打开,而是先将该数据库整个删除,然后再重启数据库服务

4.以下代码是一个简单的schema特殊用法示例

//导入模块

var mongoose = require('mongoose');

//连接数据库
mongoose.connect('mongodb://localhost/itheima');

//创建schema

//schema第一个参数是我们自定义的数据类型  第二个参数是管理schema默认的数据类型
var studentSchema = mongoose.Schema({
name:{type:String,required:true},//数据类型为string,不能非空
age:{type:Number,default:18},//数据类型为string,默认值18
study_id:{type:Number,select:true},//学号,默认查询字段
address:{type:String,lowercase:true},//地址,默认小写
email:{type:String,match:RegExp(/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/)},//邮箱,正则表达式验证
phone:{type:String,unique:true,dropDups: true}//电话号码唯一性
},{
versionKey: false,//去掉版本锁 __v0

timestamps: { createdAt: 'createTime', updatedAt: 'updateTime' }//自动管理修改时间

});

//创建model

var student = mongoose.model('student',studentSchema);

//创建Entity

var zhangsan = new student({
name:'zhangsan',//名字必须要有,否则会报错: name: Path `name` is required.
address:'ZhongLiang',//字符串都会变成小写
email:'a12345@qq.com',//邮箱格式不对,添加会报错 Path `email` is invalid (a12345qq.com).
study_id:2017001,
phone:'123456789'//在添加唯一性字段时,mongoose会先查询数据库所有的phone值,一旦发现该值已存在则会报错
});

//添加数据

student.create(zhangsan,function(err){

if(err){
throw err;
}

console.log('插入成功' + zhangsan);

});
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐