mongoose設(shè)置unique不生效問(wèn)題的解決及如何移除unique的限制
前言
unique屬于schema約束驗(yàn)證中的一員,他的作用主要就是讓某一個(gè)字段的值具有唯一性(不能重復(fù))
保持字段的唯一性使用type值: {type:String,unique:true,dropDups: true}
注意:mongoose一旦修改了數(shù)據(jù)存儲(chǔ)的機(jī)構(gòu),數(shù)據(jù)庫(kù)一定要重啟,很多新手在設(shè)置一些屬性不生效時(shí)都是這個(gè)原因
這里說(shuō)的重啟,不是簡(jiǎn)單的關(guān)閉mongoose數(shù)據(jù)庫(kù)服務(wù)器重新打開(kāi),而是先將該數(shù)據(jù)庫(kù)整個(gè)刪除,然后再重啟數(shù)據(jù)庫(kù)服務(wù)
簡(jiǎn)單的schema特殊用法示例
//導(dǎo)入模塊
var mongoose = require('mongoose');
//連接數(shù)據(jù)庫(kù)
mongoose.connect('mongodb://localhost/itheima');
//創(chuàng)建schema
//schema第一個(gè)參數(shù)是我們自定義的數(shù)據(jù)類(lèi)型 第二個(gè)參數(shù)是管理schema默認(rèn)的數(shù)據(jù)類(lèi)型
var studentSchema = mongoose.Schema({
name:{type:String,required:true},//數(shù)據(jù)類(lèi)型為string,不能非空
age:{type:Number,default:18},//數(shù)據(jù)類(lèi)型為string,默認(rèn)值18
study_id:{type:Number,select:true},//學(xué)號(hào),默認(rèn)查詢(xún)字段
address:{type:String,lowercase:true},//地址,默認(rèn)小寫(xiě)
email:{type:String,match:RegExp(/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/)},//郵箱,正則表達(dá)式驗(yàn)證
phone:{type:String,unique:true,dropDups: true}//電話(huà)號(hào)碼唯一性
},{
versionKey: false,//去掉版本鎖 __v0
timestamps: { createdAt: 'createTime', updatedAt: 'updateTime' }//自動(dòng)管理修改時(shí)間
});
//創(chuàng)建model
var student = mongoose.model('student',studentSchema);
//創(chuàng)建Entity
var zhangsan = new student({
name:'zhangsan',//名字必須要有,否則會(huì)報(bào)錯(cuò): name: Path `name` is required.
address:'ZhongLiang',//字符串都會(huì)變成小寫(xiě)
email:'a12345@qq.com',//郵箱格式不對(duì),添加會(huì)報(bào)錯(cuò) Path `email` is invalid (a12345qq.com).
study_id:2017001,
phone:'123456789'//在添加唯一性字段時(shí),mongoose會(huì)先查詢(xún)數(shù)據(jù)庫(kù)所有的phone值,一旦發(fā)現(xiàn)該值已存在則會(huì)報(bào)錯(cuò)
});
//添加數(shù)據(jù)
student.create(zhangsan,function(err){
if(err){
throw err;
}
console.log('插入成功' + zhangsan);
});
Mongoose 移除unique的限制
程序中email最開(kāi)始設(shè)置了unque限制,導(dǎo)致email在此collection中無(wú)法重復(fù)插入,現(xiàn)在想要移除unique限制。
db.your_collection.dropIndexes();
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
- MongoDB性能篇之創(chuàng)建索引,組合索引,唯一索引,刪除索引和explain執(zhí)行計(jì)劃
- MongoDB索引使用詳解
- MongoDB的基礎(chǔ)查詢(xún)和索引操作方法總結(jié)
- pymongo給mongodb創(chuàng)建索引的簡(jiǎn)單實(shí)現(xiàn)方法
- MongoDB中創(chuàng)建索引需要注意的事項(xiàng)
- mongodb處理中文索引與查找字符串詳解
- MongoDB數(shù)據(jù)庫(kù)中索引(index)詳解
- 深入理解MongoDB的復(fù)合索引
- Mongodb索引的優(yōu)化
- MongoDB中唯一索引(Unique)的那些事
相關(guān)文章
webstorm中配置nodejs環(huán)境及npm的實(shí)例
今天小編就為大家分享一篇webstorm中配置nodejs環(huán)境及npm的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-05-05
Node使用Sequlize連接Mysql報(bào)錯(cuò):Access denied for user ‘xxx’@‘localh
這篇文章主要給大家介紹了關(guān)于Node使用Sequlize連接Mysql報(bào)錯(cuò):Access denied for user 'xxx'@'localhost'的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01
npm?install常見(jiàn)報(bào)錯(cuò)以及問(wèn)題詳解
npm?install總是一言難盡,下面這篇文章主要給大家介紹了關(guān)于npm?install常見(jiàn)報(bào)錯(cuò)以及問(wèn)題的相關(guān)資料,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
node?gyp安裝canvas原生模塊編譯node?pregyp詳解
這篇文章主要為大家介紹了Nodejs關(guān)于原生模塊編譯node-gyp + node-pre-gyp (以安裝canvas為例)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11

