mongooseの独自設定が反映されない問題の解決方法と独自制限の解除方法を詳しく解説

小云云
リリース: 2017-12-26 13:25:01
オリジナル
1941 人が閲覧しました

この記事では、Mongoose データベースの固有の設定が有効にならない問題の解決策と、Mongoose の固有の制限を解除する方法の例を、サンプル コードを通じて詳しく紹介します。参考にして一緒に学びましょう。

前書き

unique は、スキーマ制約検証のメンバーです。その主な機能は、特定のフィールドの値を一意にすることです (繰り返し不可)。フィールドの一意性を維持するには、次の type 値を使用します。 :String, unique:true,dropDups: true}

注: mongoose がデータ ストレージ メカニズムを変更すると、データベースを再起動する必要があります。これが、多くの初心者が有効にならないプロパティを設定する理由です

再起動について説明しました。これは簡単ではありません。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);

});
ログイン後にコピー
Mongoose は、固有の制限を削除します

プログラムは最初に一意の制限を設定しており、電子メールをこのコレクションに繰り返し挿入できませんでした。ここで一意の制限を削除したいと考えています。

db.your_collection.dropIndexes();
ログイン後にコピー
関連する推奨事項:


mongooseでオブジェクトを更新する2つの方法

Mongooseの仮想フィールドクエリ実装方法の詳細な説明

Node.js MongoDBドライバー Mongooseの基本的な使い方tutorial_node.js

以上がmongooseの独自設定が反映されない問題の解決方法と独自制限の解除方法を詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!