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参数的小问题
Mar 02 Javascript
javascript 一个函数对同一元素的多个事件响应
Jul 25 Javascript
jQuery 使用手册(六)
Sep 23 Javascript
jQuery.Validate验证库的使用介绍
Apr 26 Javascript
给事件响应函数传参数的四种方式小结
Dec 05 Javascript
JavaScript利用构造函数和原型的方式模拟C#类的功能
Mar 06 Javascript
js判断图片加载完成后获取图片实际宽高的方法
Feb 25 Javascript
javascript使用 concat 方法对数组进行合并的方法
Sep 08 Javascript
js断点调试心得分享(必看篇)
Dec 08 Javascript
解决angularjs service中依赖注入$scope报错的问题
Oct 02 Javascript
详解Vue 项目中的几个实用组件(ts)
Oct 29 Javascript
JavaScript实现猜数字游戏
May 20 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
.htaccess文件保护实例讲解
2011/02/06 PHP
php实现cc攻击防御和防止快速刷新页面示例
2014/02/13 PHP
php的mkdir()函数创建文件夹比较安全的权限设置方法
2014/07/28 PHP
我整理的PHP 7.0主要新特性
2016/01/07 PHP
PHP生成可点击刷新的验证码简单示例
2016/05/13 PHP
javascript Array.sort() 跨浏览器下需要考虑的问题
2009/12/07 Javascript
Asp.Net alert弹出提示信息的几种方法总结
2014/01/29 Javascript
Jquery获取元素的父容器对象示例代码
2014/02/10 Javascript
javascript回车完美实现tab切换功能
2014/03/13 Javascript
javascript实现瀑布流自适应遇到的问题及解决方案
2015/01/28 Javascript
Angular ng-repeat 对象和数组遍历实例
2016/09/14 Javascript
Knockout结合Bootstrap创建动态UI实现产品列表管理
2016/09/14 Javascript
express文件上传中间件Multer详解
2016/10/24 Javascript
深入学习jQuery中的data()
2016/12/22 Javascript
浅析Angular2子模块以及异步加载
2017/04/24 Javascript
JavaScript禁止微信浏览器下拉回弹效果
2017/05/16 Javascript
vue ssr 实现方式(学习笔记)
2019/01/18 Javascript
layui按条件隐藏表格列的实例
2019/09/19 Javascript
javascript canvas时钟模拟器
2020/07/13 Javascript
js实现3D粒子酷炫动态旋转特效
2020/09/13 Javascript
Python解析excel文件存入sqlite数据库的方法
2016/11/15 Python
Python输入二维数组方法
2018/04/13 Python
Django重装mysql后启动报错:No module named ‘MySQLdb’的解决方法
2018/04/22 Python
Python unittest 简单实现参数化的方法
2018/11/30 Python
python机器学习实现决策树
2019/11/11 Python
python 遗传算法求函数极值的实现代码
2020/02/11 Python
python操作redis数据库的三种方法
2020/09/10 Python
python3.8动态人脸识别的实现示例
2020/09/21 Python
Python爬虫简单运用爬取代理IP的实现
2020/12/01 Python
如何用Python和JS实现的Web SSH工具
2021/02/23 Python
《灯光》教学反思
2014/02/08 职场文书
企业法人授权委托书
2014/09/25 职场文书
教学改革问题查摆整改措施
2014/09/27 职场文书
生产设备维护保养制度
2015/08/06 职场文书
反邪教教育心得体会
2016/01/15 职场文书
详解MySQL多版本并发控制机制(MVCC)源码
2021/06/23 MySQL