mongoose包操作mongoDB

來源:互聯網
上載者:User

標籤: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

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.