この記事では、Mongoose データベースの固有の設定が有効にならない問題の解決策と、Mongoose の固有の制限を解除する方法の例を、サンプル コードを通じて詳しく紹介します。参考にして一緒に学びましょう。
前書き
unique は、スキーマ制約検証のメンバーです。その主な機能は、特定のフィールドの値を一意にすることです (繰り返し不可)。フィールドの一意性を維持するには、次の type 値を使用します。 :String, unique:true,dropDups: true}
注: mongoose がデータ ストレージ メカニズムを変更すると、データベースを再起動する必要があります。これが、多くの初心者が有効にならないプロパティを設定する理由です
簡単なスキーマの特殊な使用例
//导入模块 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); });
db.your_collection.dropIndexes();
mongooseでオブジェクトを更新する2つの方法
Node.js MongoDBドライバー Mongooseの基本的な使い方tutorial_node.js
以上がmongooseの独自設定が反映されない問題の解決方法と独自制限の解除方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。