一、Mongoose 校验参数
在定义Schema时,可以设置数据的校验参数,这样可以对操作数据库数据时,对其做进一步的规范。主要的校验参数有:
-
required
: 数据可以是任意类型,表示这个数据必须传入 -
max
: 用于Number 类型数据,最大值 -
min
: 用于Number 类型数据,最小值 -
enum
:枚举类型(数组中的类型是String),要求数据必须满足枚举值enum: ['0', '1', '2'] -
match
:增加的数据必须符合match(正则)的规则 -
maxlength
:数据必须是String类型,数据最大长度 -
minlength
:数据必须是String类型,数据最小长度
1.1 required
示例:
// 定义news_id是必须要传入的数据
const NewsSchema = mongoose.Schema({
news_id:{
type:Number,
// 唯一索引
unique: true,
required: true
},
title: {
type:String,
// 普通索引
index: true
},
author: String
});
const News = mongoose.model('News', NewsSchema, 'news');
module.exports = News;
现在我们在news
集合中添加数据时,如果没有传入news_id
的字段数据,就会报错:
const news = new News({
/*此处没有传入news_id数据*/
title: '新闻1',
author: 'joyitsai'
})
news.save((err, docs)=>{
if(err) return console.log(err);
console.log(docs);
})
运行报错:
{ ValidationError: News validation failed: news_id: Path `news_id` is required.
.....
}
1.2 max
和min
示例:
如果Schema定义时,指定max
和min
,那么传入的数据值必须在min和max之间,否则报错:
const NewsSchema = mongoose.Schema({
news_id:{
type:Number,
// 唯一索引
unique: true,
},
title: {
type:String,
// 普通索引
index: true
},
author: String,
words: {
type: Number,
min: 200,
max: 1000
}
});
const News = mongoose.model('News', NewsSchema, 'news');
module.exports = News;
现在如果添加数据时words为100:
const news = new News({
news_id: 2,
title: '新闻2',
author: 'joyitsai',
words: 100
})
news.save((err, docs)=>{
if(err) return console.log(err);
console.log(docs);
})
就会提示数据不能小于min
的值,相反如果数据大于max
也会提示相应错误:
{ ValidationError: News validation failed: words: Path `words` (100) is less than minimum allowed value (1000).
......
}
其他的几个参数就不一一举例了,请自行验证。
二、自定义校验:
类似于之前set
的用法,在定义Schema时可以用validate
关键字自定义一个校验器函数
,来检测数据是否满足想要的规范,如果通过验证返回true,没有通过则返回false:
const NewsSchema = mongoose.Schema({
news_id:{
type:Number,
// 唯一索引
unique: true,
},
title: {
type:String,
// 普通索引
index: true
},
author: String,
content: {
type: String,
/*words的长度要大于8且小于20*/
validate: function(words){
return (words.length>=8 && words.length<=20)
}
}
});
添加数据时:
const news = new News({
news_id: 2,
title: '新闻2',
author: 'joyitsai',
words: 'qwert'
})
news.save((err, docs)=>{
if(err) return console.log(err);
console.log(docs);
})
提示报错:
{ ValidationError: News validation failed: words: Validator failed for path `words` with value `qwert`
......
}
如果添加的words数据长度在8-20之间,就没问题了:
{ _id: 5cfd15eacf0cee3f14f5bb85,
news_id: 2,
title: '新闻2',
author: 'joyitsai',
words: 'qwertyuio',
__v: 0 }