標籤:efi mod 回調 分頁 自訂 屬性 對象 date validate
閱讀此文需要有mongoDB的基礎知識在nodejs裡操作mongo資料庫先瞭解幾個概念:mongodb和mongoosemongodb包是為程式提供的一個驅動來操作mongoDB資料庫mongoose包是基於mongodb構建的一個對象操作模型,適用於nodejsmongoose中比較重要的三個概念:Schema,用來定義資料庫的結構,比如key的資料類型,文檔裡都有哪些key,key的value值都有哪些特徵等。schema不具備操作資料庫的能力。Model,由schema編譯出的構造器,用來定義集合模型,Model的執行個體即是文檔。model具備資料庫的增刪改查。Entity,由model構造器建立的實體,即文檔document。var mongoose = require(‘mongoose‘)串連資料庫usermongoose.connect("mongodb://127.0.0.1:27017/user")定義schemavar userSchema = new mongoose.Schema({ id:Number, name:{reuired:true,default:‘undefined‘,match:/a/}, age:Number})schema還可以細化key的其他屬性,即文檔驗證,通過文檔驗證的文檔才會被儲存,反正則不會儲存,還會報錯。type:資料類型,如Number,Stringrequired: true資料必須填寫, false非必須資料default: 預設值validate: 自訂匹配,值是自訂函數,傳回值是布爾值,true通過,false不通過min: 最小值(只適用於數字)max: 最大值(只適用於數字)match: 正則匹配(只適用於字串)enum: 枚舉匹配(只適用於字串)定義model,其中testco即是集合名var userModel = mongoose.model(‘testco‘,userSchema)產生entityvar doc = new userModel({ id:1, name:‘aa‘, age:23 })定製化的schema需要new mongoose.Schema()model則是調用mongoose.model()定製化entity則需要new model()在mongo的shell後台裡,操作方法基本都是在集合下調用,mongoose也是如此,model充當的集合的角色,自然也是在它下操作資料庫。參考連結:http://www.nodeclass.com/api/mongoose.html#model-js增Model.create(doc(s),(err,doc(s))=>{})eg.userModel.create({id:2,name:"bb",age:33},{id:3,name:"cc",age:3},(err,doc1,doc2)=>{ console.log(doc1) //{id:2,name:"bb",age:33} console.log(doc2) //{id:3,name:"cc",age:3}})new Model(doc).save()eg.new userModel({id:1,name:‘aa‘,age:23}).save()刪在model上刪文檔Model.remove(conditions,(err,doc)=>{})在文檔上刪文檔eg.Model.find({id:{$lte:5}},(err,docs)=>{ docs.remove()})改Model.update(conditions,update,(err,raw)=>{})查Model.find(conditions, [fields], [options], [(err,docs)=>{}])參數:查詢條件,控制返回的欄位(欄位篩選),配置查詢參數,回呼函數conditions查詢條件參考mongo文法,比如$lte:32之類的fields即是控制返回資料的欄位,就是說你想要哪些key,想要返回name就寫‘name‘,此時預設會返回_id值,寫成{name:1,_id:0}即可options配置查詢參數,比如做分頁的時候{limit:20}表示返回20條資料(不足返回全部)callback中err表示查詢錯誤,docs表示返回的結果.findOne()表示返回資料中的第一條,.findById()表示根據obj.id尋找查詢後操作sort 排序skip 跳過limit 限制select 顯示欄位exec 執行id降序,age升序排序Model.find().sort(‘-id age‘).exec((err,docs)=>{})跳過前三條資料Model.find().skip(3).exec((err,docs)=>{})只顯示13條資料Model.find().limit(13).exec((err,docs)=>{})只顯示name age欄位,不顯示idModel.find().select(‘name age -id‘).exec((err,docs)=>{})以上可以連起來寫,尋找到的資料按id降序age升序,跳過前3,只顯示13條,每條資料只顯示name,age欄位,不顯示idModel.find().sort(‘-id age‘).skip(3).limit(13).select(‘name age -id‘).exec((err,docs)=>{ console.log(docs)})分頁小例子:定義頁碼,定義每頁多少條,定義let page = req.param(‘page‘)let pageSize = 20let skip = (page-1)*pageSizemodel.find().skip(skip).limit(pageSize).exec((err,docs)=>{ if (err) { data.push({ status = 1, msg:‘資料錯誤‘ }) }else{ data.push(doc) }})
mongoose包操作mongoDB