mongooseの独自設定が反映されない問題の解決方法

小云云
リリース: 2018-01-19 13:46:07
オリジナル
2284 人が閲覧しました

この記事では、主にmongooseデータベースの固有設定が反映されない問題の解決方法と、mongooseの固有制限を解除する方法の一例をサンプルコードを交えて詳しく紹介します。 . 必要な友達が参考になれば幸いです。

前書き

unique は、スキーマ制約検証のメンバーです。その主な機能は、特定のフィールドの値を一意にすることです (繰り返し不可)。フィールドの一意性を維持するには、type value: {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 は独自の制限を削除します

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

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


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

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

インストール Node.js_node.js で Mongoose を使用して MongoDB を操作するための基本チュートリアル

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

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