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 相关文章推荐
二行代码解决全部网页木马
Mar 28 Javascript
JQuery中$.ajax()方法参数详解及应用
Dec 12 Javascript
js字符串日期yyyy-MM-dd转化为date示例代码
Mar 06 Javascript
jQuery学习笔记之基础中的基础
Jan 19 Javascript
javascript中关于&& 和 || 表达式的小技巧分享
Apr 10 Javascript
javascript实现dom动态创建省市纵向列表菜单的方法
May 14 Javascript
javascript实现动态导入js与css等静态资源文件的方法
Jul 25 Javascript
JavaScript实现页面跳转的几种常用方式
Nov 28 Javascript
BootStrap modal模态弹窗使用小结
Oct 26 Javascript
JavaScript实现随机点名器实例详解
May 07 Javascript
Element-ui DatePicker显示周数的方法示例
Jul 19 Javascript
微信小程序中限制激励式视频广告位显示次数(实现思路)
Dec 06 Javascript
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 会话(session 时间设定)使用入门代码
2008/06/05 PHP
simplehtmldom Doc api帮助文档
2012/03/26 PHP
Yii2实现多域名跨域同步登录退出
2017/02/04 PHP
PHP中CheckBox多选框上传失败的代码写法
2017/02/13 PHP
jquery validate.js表单验证的基本用法入门
2010/05/13 Javascript
Iframe自适应高度绝对好使的代码 兼容IE,遨游,火狐
2011/01/27 Javascript
Extjs优化(一)删除冗余代码提高运行速度
2013/04/15 Javascript
实例讲解JS中数组Array的操作方法
2014/05/09 Javascript
JavaScript中的数学运算介绍
2014/12/29 Javascript
JavaScript中的fontsize()方法使用详解
2015/06/08 Javascript
浅谈jQuery中setInterval()方法
2015/07/07 Javascript
Bootstrap按钮下拉菜单组件详解
2016/05/10 Javascript
完美JQuery图片切换效果的简单实现
2016/07/21 Javascript
Vue.js第四天学习笔记(组件)
2016/12/02 Javascript
从零开始搭建webpack+react开发环境的详细步骤
2018/05/18 Javascript
async/await优雅的错误处理方法总结
2019/01/30 Javascript
在Web关闭页面时发送Ajax请求的实现方法
2019/03/07 Javascript
vue使用el-upload上传文件及Feign服务间传递文件的方法
2019/03/15 Javascript
Javascript读写cookie的实例源码
2019/03/16 Javascript
Vue之beforeEach非登录不能访问的实现(代码亲测)
2019/07/18 Javascript
利用JS响应式修改vue实现页面的input值
2019/09/02 Javascript
node 解析图片二维码的内容代码实例
2019/09/11 Javascript
vue实现购物车的监听
2020/04/20 Javascript
ssh批量登录并执行命令的python实现代码
2012/05/25 Python
Python处理json字符串转化为字典的简单实现
2016/07/07 Python
同时安装Python2 & Python3 cmd下版本自由选择的方法
2017/12/09 Python
Pycharm以root权限运行脚本的方法
2019/01/19 Python
基于pytorch的保存和加载模型参数的方法
2019/08/17 Python
详解Anconda环境下载python包的教程(图形界面+命令行+pycharm安装)
2019/11/11 Python
pytorch ImageFolder的覆写实例
2020/02/20 Python
TensorFlow固化模型的实现操作
2020/05/26 Python
Python filter过滤器原理及实例应用
2020/08/18 Python
幼儿园校车司机的岗位职责
2014/01/30 职场文书
2019年第四季度财务部门工作计划
2019/11/02 职场文书
Jupyter Notebook 如何修改字体和大小以及更改字体样式
2021/06/03 Python
基于Python实现将列表数据生成折线图
2022/03/23 Python