独自の制限を解除する方法

php中世界最好的语言
php中世界最好的语言オリジナル
2018-04-14 16:57:192217ブラウズ

今回は独自の制限を解除する方法を紹介します。 注意事項を実際に見てみましょう。

はじめに

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();

この記事の事例を読んだ後は、この方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。

推奨読書:

JSはナビゲーションバーの透明なグラデーションを実装します

Nodeのモジュールシステムの使い方の詳細な説明


Bootstrapでテーブルを操作する方法


以上が独自の制限を解除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。