Node.js的MongoDB驅(qū)動(dòng)Mongoose基本使用教程
使用mongoose可以讓我們更好使用mongodb數(shù)據(jù)庫,而不需要寫繁瑣的業(yè)務(wù)邏輯。
安裝
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中,所有的數(shù)據(jù)都是一種模式,每個(gè)模式都映射到mongodb的集合,并且定義該集合文件結(jié)構(gòu)。
//這里建立一個(gè)動(dòng)物的模式,所有動(dòng)物都擁有這個(gè)模式下的所有屬性 var animalSchema = new Schema({ name: String, age: Number, });
模型是我們從Schema中定義的一種多樣化的構(gòu)造函數(shù),模型的實(shí)例可以使用很多操作,所有文檔的創(chuàng)建和檢索都是由模型來處理
var animalMode = db.model('Animal', animalSchema);
模型的實(shí)例實(shí)質(zhì)是文件,而我們可以很輕松創(chuàng)建、修改這種文件
var cat = new animalMode({ name: 'catName', age: '7', //這里依然使用字符串,mongoose會(huì)自動(dòng)轉(zhuǎn)換類型 }); 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); //}); //執(zhí)行查找 animalMode.find(function(err, people){ if(err) console.log(err); console.log(people); }); //查找符合條件數(shù)據(jù) animalMode.findOne({title: 'catName'}, function(err, cat){ if(err) console.log(err); console.log(cat); });
Schema
數(shù)據(jù)類型
這是Schema中所有的數(shù)據(jù)類型,包括mongoose自定的數(shù)據(jù)類型
- String
- Number
- Date
- Buffer
- Boolean
- Mixed
- ObjectId
- Array
每種數(shù)據(jù)類型的使用
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自定義的一種混合類型,因?yàn)镸ixed沒有定義具體內(nèi)容,可以用{}來使用,以下2種定義形式等價(jià)。
var animalSchema = new Schema({any: {}}); var animalSchema = new Schema({any: {Schema.Types.Mixed}});
自定義方法
可以為Schema綁定方法
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); });
也可以為Schema添加靜態(tài)方法
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數(shù)據(jù)建立索引,mongodb支持二級(jí)索引,為了提高數(shù)據(jù)查找和定位,建立復(fù)合索引是必要的
var animalSchema = new Schema({ name: String, age: Number, tags: { age: [String], index: true } // field level }); animalSchema.index({ name: 1, age: -1 }); // schema level
但是這種索引的建立可能導(dǎo)致顯著的性能影響,建議在生產(chǎn)下停止,將設(shè)置模式下的自動(dòng)索引設(shè)置為false禁止
animalSchema.set('autoIndex', false); // or new Schema({..}, { autoIndex: false });
Model
C
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 作為參數(shù),返回單個(gè)文檔。_id //可以是字符串或 ObjectId 對象。 animalMode.findById(id, function(err, adventure){ if (err) consoel.log(err); console.log(adventure); }); //where //查詢數(shù)據(jù)類型是字符串時(shí),可支持正則 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); });
U
官方文檔提供的更新函數(shù)Model.update
Model.update(conditions, doc, [options], [callback])
- conditions 更新條件
- doc 更新內(nèi)容
- option 更新選項(xiàng)
- safe (boolean) 安全模式,默認(rèn)選項(xiàng),值為true
- upsert (boolean) 條件不匹配時(shí)是否創(chuàng)建新文檔,默認(rèn)值為false
- multi (boolean) 是否更新多個(gè)文件,默認(rèn)值為false
- strict (boolean) 嚴(yán)格模式,只更新一條數(shù)據(jù)
- overwrite (boolean) 覆蓋數(shù)據(jù),默認(rèn)為false
- callback
- err 更新數(shù)據(jù)出錯(cuò)時(shí)返回值
- numberAffected (筆者暫時(shí)不清楚)
- rawResponse 受影響的行數(shù)
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); })
其它
//返回文檔數(shù)
animalMode.count({age: 2}, function(err, cat){ if (err) console.log(err); console.log(cat); })
- node.js連接mongoose數(shù)據(jù)庫方法詳解
- node.js使用mongoose操作數(shù)據(jù)庫實(shí)現(xiàn)購物車的增、刪、改、查功能示例
- node.js利用mongoose獲取mongodb數(shù)據(jù)的格式化問題詳解
- Node.js+jade+mongodb+mongoose實(shí)現(xiàn)爬蟲分離入庫與生成靜態(tài)文件的方法
- Node.js中使用mongoose操作mongodb數(shù)據(jù)庫的方法
- 安裝使用Mongoose配合Node.js操作MongoDB的基礎(chǔ)教程
- node.js mongoose index索引操作
相關(guān)文章
Windows 系統(tǒng)下設(shè)置Nodejs NPM全局路徑
這篇文章主要介紹了Windows 系統(tǒng)下設(shè)置Nodejs NPM全局路徑2016-04-04Node.js 條形碼識(shí)別程序構(gòu)建思路詳解
這篇文章主要介紹了Node.js 條形碼識(shí)別程序構(gòu)建思路詳解的相關(guān)資料,需要的朋友可以參考下2016-02-02node實(shí)現(xiàn)批量上傳本地圖片轉(zhuǎn)為圖片CDN的項(xiàng)目實(shí)踐
本文主要介紹了node實(shí)現(xiàn)批量上傳本地圖片轉(zhuǎn)為圖片CDN的項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07使用Make構(gòu)建Node.js網(wǎng)站項(xiàng)目
這篇文章介紹了使用Make構(gòu)建Node.js網(wǎng)站項(xiàng)目的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)
這篇文章主要為大家介紹了React和Node.js快速上傳進(jìn)度條功能實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03Node如何后臺(tái)數(shù)據(jù)庫使用增刪改查功能
這篇文章主要介紹了Node如何后臺(tái)數(shù)據(jù)庫使用增刪改查功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11