安裝mongoose
使用express準備一個TestMongoDB項目,命令序列如下:
express TestMongoDBcd TestMongoDBnpm install
執行完上面的命令後,使用下面的命令安裝mongoose:
npm install mongoose --save
這個命令會安裝mongoose並將其作為項目的依賴,而mongoose依賴的MongoDB driver以及regexp等等模組也會被自動安裝。
執行個體
使用mongoose可以建立資料庫、建立集合、對集合內的文檔進行CRUD操作,在寫代碼時,可以對照著mongo shell驗證結果是否符合預期。
在TestMongoDB下建立一個mongo.js檔案,內容如下:
var mongoose = require('mongoose');mongoose.connect('mongodb://localhost/accounts');var db = mongoose.connection;db.on('error', console.error.bind(console, 'connection error:'));db.once('open', function() { console.log('mongoose opened!'); var userSchema = new mongoose.Schema({ name:{type: String, unique: true}, password:String }, {collection: "accounts"} ); var User = mongoose.model('accounts', userSchema); User.findOne({name:"WangEr"}, function(err, doc){ if(err) console.log(err); else console.log(doc.name + ", password - " + doc.password); }); var lisi = new User({name:"LiSi", password:"123456"}); lisi.save(function(err, doc){ if(err)console.log(err); else console.log(doc.name + ' saved'); }); });
上面的檔案,直接執行“node mongo.js”命令即可查看效果。
要使用mongoose,先require,然後使用connect方法串連資料庫。connect原型:
connect(uri, options, [callback])
uri的格式類似:“mongodb://user:pass@localhost:port/database”。
mongoose的connection對象定義了一些事件,比如connected、open、close、error等,我們可以監聽這些事件。
在我們的範例程式碼裡,我監聽了open事件,在回呼函數中,定義了Schema,調用mongoose.model來編譯Schema得到Model對象。需要注意的是,定義Schema時指定的collection名字與mongoose.model的第一參數要保持一致。
拿到了Model對象,就可以執行增刪改查等操作了。Model對象有find()、findOne()、update()、remove()等方法,和我們在mongo shell裡的用法類似。這些方法都有一個可選的callback,當你提供這些callback時,執行的結果會通過這個callback返回給你。如果你不提供,這些方法會返回一個Query對象,你可以再通過Query組裝新的選項,然後調用Query的exec(callback)來提交查詢。
我在代碼裡尋找WangEr的檔案時用了callback,沒用Query。
Model對象有個Model(doc)方法,用來構造一個文檔(Document)。建立Lisi的文檔時就是這種Document對象的save()方法可以將文檔儲存到資料庫。
通過mongoose進行的基本操作:
1、增
var obj = new Movie();obj.title = '標題一';obj.content = '內容';obj.save(function(err) { });
2、刪
Movie.remove({ _id:id},function (err) { })
3、改
Movie.update({ _id:id},json,{},function (err) { })
4、查
Movie.findOne({ _id: id}, function(err, obj) { });Movie.find({}).sort({_id: -1}).limit(3).exec(function(err, obj) { })