ホームページ > ウェブフロントエンド > jsチュートリアル > Node.js MongoDBドライバー Mongooseの基本的な使い方tutorial_node.js

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

WBOY
リリース: 2016-05-16 15:12:43
オリジナル
1807 人が閲覧しました

mongoose を使用すると、面倒なビジネス ロジックを作成せずに、mongodb データベースをより効果的に使用できるようになります。

インストール

npm install mongoose
ログイン後にコピー


を使用して初期化します
mongoose を使用する前に、node と mongodb をインストールする必要があります。node と mongodb のインストール方法についてはここでは説明しません。

 var mongoose = require("mongoose");
 var Schema = mongoose.Schema;
 var db = mongoose.connection;
 mongoose.connect('mongodb://localhost/animal');
 db.on('error', console.error);
 db.once('open', function() {
  //这里建立模式和模型
 }
ログイン後にコピー

クイックスタート
mongoose では、すべてのデータはスキーマであり、各スキ​​ーマは mongodb コレクションにマップされ、コレクション ファイル構造を定義します。

 //这里建立一个动物的模式,所有动物都拥有这个模式下的所有属性
 var animalSchema = new Schema({
  name: String,
  age: Number,
 });
ログイン後にコピー

モデルは、スキーマから定義する多様なコンストラクターです。モデルのインスタンスでは、すべてのドキュメントの作成と取得がモデルによって処理されます。

 var animalMode = db.model('Animal', animalSchema);
ログイン後にコピー

モデルのインスタンスは本質的にファイルであり、そのようなファイルは簡単に作成および変更できます

 var cat = new animalMode({
  name: 'catName',
  age: '7', //这里依然使用字符串,mongoose会自动转换类型
  });

 cat.save(function(err, thor) {
  if (err) return console.log(err);
  console.log(thor);
 });
 //或者可以使用create
 //cat.create(function(err, thor) {
 // if (err) return console.log(err);
 // console.log(thor);
 //});

 //执行查找
 animalMode.find(function(err, people){
  if(err) console.log(err);
  console.log(people);
 });
 //查找符合条件数据
 animalMode.findOne({title: 'catName'}, function(err, cat){
  if(err) console.log(err);
  console.log(cat);
 });

ログイン後にコピー

スキーマ
データ型

これらは、mongoose のカスタム データ型を含むスキーマのすべてのデータ型です

  • 文字列
  • 番号
  • 日付
  • バッファ
  • ブール値
  • 混合
  • オブジェクト ID
  • 配列

各データ型の使用法

 var animalMode = mongoose.model('Animal', schema);

 var cat = new animalMode;
 cat.name = 'Statue of Liberty'    //String
 cat.age = '7';        //Number
 cat.updated = new Date;      //Date
 cat.binary = new Buffer(0);     //Buffer
 cat.living = false;       //Boolean
 cat.mixed = { any: { thing: 'i want' } }; //Mixed    
 cat._someId = new mongoose.Types.ObjectId; //ObjectId
 cat.ofString.push("strings!");    //Array

ログイン後にコピー

Mixed は mongoose によってカスタマイズされた混合型です。Mixed は特定の内容を定義しないため、次の 2 つの定義形式は同等です。

 var animalSchema = new Schema({any: {}});
 var animalSchema = new Schema({any: {Schema.Types.Mixed}});
ログイン後にコピー

カスタムメソッド

メソッドをスキーマにバインドできます

 var animalSchema = new Schema({
  name: String,
  age: Number,
 });

 animalSchema.methods.findSimilarTypes = function (cb) {
  return this.model('Animal').find({ name: this.name }, cb);
 }

 var animalMode = db.model('Animal', animalSchema);

 cat.findSimilarTypes(function(err, cat){
  if(err) console.log(err);
  console.log(cat);
 });

ログイン後にコピー

静的メソッドをスキーマに追加することもできます

 animalSchema.statics.findByName = function (name, cb) {
  return this.find({ name: new RegExp(name, 'i') }, cb);
 }
 var animalMode = db.model('Animal', animalSchema);

 animalMode.findByName('catName', function (err, animals) {
  console.log(animals);
 });

ログイン後にコピー

インデックス

mongodb データにインデックスを付けることができます。Mongodb はセカンダリ インデックスをサポートしています。データの検索と位置決めを改善するには、複合インデックスを確立する必要があります。

 var animalSchema = new Schema({
  name: String,
  age: Number,
  tags: { age: [String], index: true } // field level
 });

 animalSchema.index({ name: 1, age: -1 }); // schema level

ログイン後にコピー

ただし、この種のインデックスの確立は、パフォーマンスに重大な影響を与える可能性があります。運用環境ではこれを停止し、セットアップ モードで自動インデックス作成を false に設定して無効にすることをお勧めします。

 animalSchema.set('autoIndex', false);
 // or
 new Schema({..}, { autoIndex: false });
ログイン後にコピー

モデル

 cat.save(function(err, thor) {
  if (err) return console.log(err);
  console.log(thor);
 });
 //或者可以使用create
 cat.create(function(err, thor) {
  if (err) return console.log(err);
  console.log(thor);
 });
ログイン後にコピー

R

//find
animalMode.find(function(err, cat){
 if (err) console.log(err);
 console.log(cat);
})

//findOne
animalMode.findOne({name: 'catName'}, function(err, cat){
 if (err) console.log(err);
 console.log(cat);
})

//findByID
//与 findOne 相同,但它接收文档的 _id 作为参数,返回单个文档。_id //可以是字符串或 ObjectId 对象。
animalMode.findById(id, function(err, adventure){
 if (err) consoel.log(err);
 console.log(adventure);
});

//where
//查询数据类型是字符串时,可支持正则
animalMode.where('age', '2').exec(function(err, cat){
 if (err) console.log(err);
 console.log(cat);
});

animalMode
 .where('age').gte(1).lte(10)
 .where('name', 'catName')
 .exec(function(err, cat){
  if (err) console.log(err);
  console.log(cat);
 });

ログイン後にコピー


公式ドキュメントが提供する更新関数 Model.update

Model.update(条件, ドキュメント, [オプション], [コールバック])

  • 条件更新条件
  • ドキュメントの内容が更新されました
  • オプション更新オプション
  • safe (ブール値) セーフ モード、デフォルト オプション、値は true
  • upsert (boolean) 条件が一致しない場合に新しいドキュメントを作成するかどうか、デフォルト値は false
  • multi (ブール値) 複数のファイルを更新するかどうか、デフォルト値は false
  • strict (ブール値) 厳密モード、1 つのデータのみを更新します
  • overwrite (ブール値) データを上書きします、デフォルトは false
  • コールバック
  • データの更新中にエラーが発生した場合に返されるエラー値
  • 影響を受ける番号 (まだわかりません)
  • rawResponse 影響を受ける行数
animalMode.update({name: 'catName'}, {age: '6'}, {multi : true}, function(err, numberAffected, raw){
 if (err) return console.log(err);
 console.log('The number of updated documents was %d', numberAffected);
 console.log('The raw response from Mongo was ', raw);
});
ログイン後にコピー

D

animalMode.remove({age: 6}, function(err){
 if (err) console.log(err);
})
ログイン後にコピー

その他
//ドキュメントの数を返します

animalMode.count({age: 2}, function(err, cat){
 if (err) console.log(err);
 console.log(cat);
})
ログイン後にコピー

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート