mongoose设置unique不生效问题的解决及如何移除unique的限制


Posted in Javascript onNovember 07, 2017

前言

unique属于schema约束验证中的一员,他的作用主要就是让某一个字段的值具有唯一性(不能重复)

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

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

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

简单的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);

});

Mongoose 移除unique的限制

程序中email最开始设置了unque限制,导致email在此collection中无法重复插入,现在想要移除unique限制。

db.your_collection.dropIndexes();

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
通过JavaScript使Div居中并随网页大小改变而改变
Jun 24 Javascript
html5的自定义data-*属性和jquery的data()方法的使用示例
Aug 21 Javascript
js实现完美兼容各大浏览器的人民币大小写相互转换
Oct 29 Javascript
JS图片定时翻滚效果实现方法
Jun 21 Javascript
Bootstrap页面缩小变形的快速解决办法
Feb 03 Javascript
jQuery实现单击按钮遮罩弹出对话框效果(1)
Feb 20 Javascript
JavaScript 中 apply 、call 的详解
Mar 21 Javascript
从零开始学习Node.js系列教程之设置HTTP头的方法示例
Apr 13 Javascript
解决vue.js 数据渲染成功仍报错的问题
Aug 25 Javascript
详解vue 不同环境配置不同的打包命令
Apr 07 Javascript
详解Vue依赖收集引发的问题
Apr 22 Javascript
js/jQuery实现全选效果
Jun 17 jQuery
vue组件父与子通信详解(一)
Nov 07 #Javascript
vue组件父子间通信之综合练习(聊天室)
Nov 07 #Javascript
Mint UI 基于 Vue.js 移动端组件库
Nov 07 #Javascript
vue中SPA单页面应用程序详解
Nov 07 #Javascript
vue-router实现组件间的跳转(参数传递)
Nov 07 #Javascript
详解Vue路由钩子及应用场景(小结)
Nov 07 #Javascript
Vue-Router实现组件间跳转的三种方法
Nov 07 #Javascript
You might like
PHP中通过ADO调用Access数据库的方法测试不通过
2006/12/31 PHP
PHP程序员最常犯的11个MySQL错误小结
2010/11/20 PHP
PHP三种方式实现链式操作详解
2017/01/21 PHP
浅谈ThinkPHP中initialize和construct的区别
2017/04/01 PHP
PHP封装的PDO数据库操作类实例
2017/06/21 PHP
php-7.3.6 编译安装过程
2020/02/11 PHP
nodejs的require模块(文件模块/核心模块)及路径介绍
2013/01/14 NodeJs
jQuery操作checkbox选择(list/table)
2013/04/07 Javascript
JavaScript等比例缩放图片控制超出范围的图片
2013/08/06 Javascript
jQuery中outerHeight()方法用法实例
2015/01/19 Javascript
js倒计时抢购实例
2015/12/20 Javascript
前端js文件合并的三种方式推荐
2016/05/19 Javascript
浅谈JavaScript 覆盖原型以及更改原型
2016/08/31 Javascript
微信小程序前端源码逻辑和工作流
2016/09/25 Javascript
JavaScript中使用webuploader实现上传视频功能(demo)
2017/04/10 Javascript
基于vue2.0实现的级联选择器
2017/06/09 Javascript
浅谈vue的踩坑路
2017/08/31 Javascript
对vue 键盘回车事件的实例讲解
2018/08/25 Javascript
js实现每日签到功能
2018/11/29 Javascript
js实现头像上传并且可预览提交
2020/12/25 Javascript
深入了解Vue动态组件和异步组件
2021/01/26 Vue.js
[04:36]DOTA2国际邀请赛 ti3精彩集锦
2013/08/19 DOTA
小结Python用fork来创建子进程注意事项
2014/07/03 Python
Python合并字符串的3种方法
2015/05/21 Python
python基础知识小结之集合
2015/11/25 Python
python 实时遍历日志文件
2016/04/12 Python
Python 实现键盘鼠标按键模拟
2020/11/18 Python
ECCO俄罗斯官网:北欧丹麦鞋履及皮具品牌
2020/06/26 全球购物
大学毕业后的十年规划
2014/01/07 职场文书
在教室放鞭炮的检讨书
2014/09/28 职场文书
学校元旦晚会开场白
2014/12/14 职场文书
个人年度总结报告
2015/03/09 职场文书
2015年司机年终工作总结
2015/05/14 职场文书
2015年教研员工作总结
2015/05/26 职场文书
JavaScript中的宏任务和微任务详情
2021/11/27 Javascript
Navicat Premium自定义 sql 标签的创建方式
2022/09/23 数据库