Eggjs笔记:Mongoose的数据校验

Mongoose 校验参数

  • required: 表示这个数据必须传入
  • max: 用于Number类型数据,最大值
  • min: 用于Number类型数据,最小值
  • enum: 枚举类型,元素需要字符类型, 要求数据必须满足枚举值,必须在枚举列表中,enum: [‘0’, ‘1’, ‘2’]
  • match: 增加的数据必须符合 match(正则)的规则
  • maxlength: 最大长度
  • minlength: 最小长度
  • 通过这些对数据的合法性进行校验
  • 包括之前我们定义字段类型,修饰符,默认参数,数据校验都是为了数据库数据的一致性

示例:

var UserSchema = new mongoose.Schema({
    name:{
        type:String, 
        required: true 
    },
    age: {
        type: Number, // 是否必须的校验器
        required: true, // 数字类型的最大值校验器
        max: 120, // 数字类型的最小值校验器
        min: 0
    },
    status: {
        type: String, // 设置字符串的可选值
        enum: ['0', '1', '2']
    },
    phone:{
        type:Number, match: /^\d{11}$/
    },
    desc: {
        type: String,
        maxlength:20,
        minlength:10
    }
});

Mongoose自定义的验证器

  • 在缺省情况下创建的索引均不是唯一索引
  • 下面的示例将创建唯一索引,如
var UserSchema = new mongoose.Schema({
    name:{
        type:String, 
        required: true,
    },
    age: {
        type: Number, // 是否必须的校验器
        required: true, // 数字类型的最大值校验器
        max: 120, // 数字类型的最小值校验器
        min: 0
    },
    status: {
        type: String, // 设置字符串的可选值
        enum: ['0', '1', '2']
    },
    phone:{
        type:Number, 
        match: /^\d{11}$/
    },
    desc: {
        type: String, // 自定义的验证器,如果通过验证返回 true,没有通过则返回 false
        validate: function(desc) {
            return desc.length >= 10;
        }
    }
});
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Wang's Blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值