NodeJs Express框架操作MongoDB數據庫執(zhí)行方法講解
1、Mongoose模塊
(1)是一個對象模型工具,是對Node.js環(huán)境下操作MongoDB數據庫進行了封裝,可以將MongoDB數據庫中的數據轉換成JavaScript對象供用戶使用。
(2)名詞:
- Schema:它是一種以文件形式存儲的數據庫模型骨架,不具備對數據庫操作的能力,僅僅只是數據庫在程序片段中的一種表現,可以理解為表結構。
- Model:由Schema發(fā)布生成的模型,具有抽象屬性和行為的數據庫操作
- Entity:由Model創(chuàng)建的實體,它的操作也會影響數據庫
(3)命名規(guī)范:駝峰命名 例:
PersonSchema:Person對應的Schema ,Person的文本屬性(表結構)
PersonModel:Person對應的Model
PersonEntity:Person對應的Entity
Schema生成Model,由Model生成Entity,Model和Entity都可以操作數據庫,Model的可操作性更強。
2、Mongoose模塊的使用
(1)安裝:npm install mongoose
(2)創(chuàng)建數據庫連接文件
// 導入mongoose模塊 const Mongoose = require('mongoose'); // 定義MongoDB數據庫的連接字符串:協(xié)議://主機地址:端口號/數據庫名 const mdb_url = 'mongodb://localhost:27017/my_test'; /* 建立和MongoDB數據庫的連接 useNewUrlParser:是否使用新的url地址轉換方式 useUnifiedTopology:是否使用新的用戶安全策略 */ Mongoose.connect(mdb_url,{useNewUrlParser:true,useUnifiedTopology:true}); // 對連接過程進行處理 // 建立連接 ——連接成功觸發(fā)connected事件 Mongoose.connection.on('connected',()=>{ console.log('數據庫連接成功~'+mdb_url); }) // 連接異常 ——回調函數的參數中保存了異常的信息 Mongoose.connection.on('error',(e)=>{ console.log(e); }) //斷開連接 ——斷開連接觸發(fā) Mongoose.connection.on('disconnected',()=>{ console.log('斷開數據庫的連接~'); }) // 導出mongoose module.exports = Mongoose;
(3)創(chuàng)建Schema,再由Schema創(chuàng)建Model
- Schema:定義的是與集合對應的骨架。Schema中的屬性對應的是MongoDB中集合的key。
- 是Schema的實例,用于操作MongoDB中的集合中的文檔。
3、關于模型名稱和數據庫中集合名稱的對應關系
(1)數據庫中沒有集合
mongoose.model('Admin',AdminSchema) ——>在模型名后加s就是集合名(不區(qū)分大小寫) ——admins
mongoose.model('Admin',AdminSchema,'admin')——>第三個參數就是用于定義的集合名稱
(2)數據庫中有集合
mongoose.model('Admin',AdminSchema,'數據庫中已有的集合名')
4、mongoose的基本操作
(1)插入文檔:save方法
- 先使用Model創(chuàng)建Entity
- 然后使用Entity調用save方法
const AdminModel = require('../model/adminModel'); // 通過model創(chuàng)建一個對象 const admin = new AdminModel({ _id:'1005', userName:'唐僧', password:'123456', address:'東土大唐' }) /* * 通過對象調用save方法向數據庫中插入數據err存放的是保存失敗后的信息 res是保存的對象 */ admin.save((err,res)=>{ if(err){ console.log(err); }else{ console.log(res); } })
(2)刪除文檔:findByIdAndDelete :直接通過Model調用,作用是根據文檔的_id屬性刪除
(3)刪除文檔:deleteOne:直接通過Model調用,根據給定的條件刪除文檔
(4)更新文檔:findOneAndUpdate,直接通過Model調用
findOneAndUpdate(條件,更新語句,{},回調函數)
AdminModel.findOneAndUpdate( {'_id':'1004'}, //表示查詢的條件 {$set:{'password':'789567'}}, //更新語句 null, //表示查詢操作,通常為null (err,data)=>{ //更新回調函數,err表示數據庫的錯誤信息,data中存放的findOne查詢到的文檔 if(err){ console.log(err); //err表示數據庫錯誤:查詢、更新時數據庫出現異常 }else if(!data){ //data為null時表示沒有找到對應的文檔 console.log('更新失敗~'); }else if(data){ //data不為null時表示找到對應的文檔 console.log('更新成功~') } })
(5)更新文檔:updateOne(條件,更新語句,回調函數)
AdminModel.updateOne({'password':'123456'},{$set:{'password':'567890'}},(err,data)=>{ if(err){ console.log(err); } console.log(data.modifiedCount); })
(6)查詢所有:find
AdminModel.find((err,data)=>{ if(err){ console.log(err); } console.log(data); })
(7)按_id查詢:findById
AdminModel.findById({ '_id':'1004' },(err,data)=>{ if(err){ console.log(err); } console.log(data); })
(8)多條件查詢:findOne 返回滿足條件的第一條記錄
AdminModel.findOne({ address:'三國', password:'123456' },(err,data)=>{ if(err){ console.log(err); } console.log(data) })
(9)查詢集合中的文檔數量 :count
AdminModel.count((err,data)=>{ if(err){ console.log(err); } console.log('記錄數:'+data); })
到此這篇關于NodeJs Express框架操作MongoDB數據庫執(zhí)行方法講解的文章就介紹到這了,更多相關NodeJs操作MongoDB數據庫內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- node.js+express+mySQL+ejs+bootstrop實現網站登錄注冊功能
- node.js平臺下利用cookie實現記住密碼登陸(Express+Ejs+Mysql)
- 零基礎搭建Node.js、Express、Ejs、Mongodb服務器及應用開發(fā)入門
- express框架通過ejs模板渲染輸出頁面實例分析
- Express 框架中使用 EJS 模板引擎并結合 silly-datetime 庫進行日期格式化的實現方法
- nodejs中的express-jwt的使用解讀
- NodeJS?Express使用ORM模型訪問關系型數據庫流程詳解
- NodeJs?Express路由使用流程解析
- NodeJs Express中間件使用流程解析
- express框架+bootstrap美化ejs模板實例分析
相關文章
[將免費進行到底]在Amazon的一年免費服務器上安裝Node.JS, NPM和OurJS博客
此文是介紹如何在Amazon的一年免費計劃上安裝Node.JS, NPM還有搭建OurJS博客系統(tǒng)。,需要的朋友可以參考下2014-08-08nodejs操作mongodb的填刪改查模塊的制作及引入實例
下面小編就為大家分享一篇nodejs操作mongodb的填刪改查模塊的制作及引入實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-01-01node實現shell命令管理工具及commander.js學習
這篇文章主要為大家介紹了node實現shell命令管理工具及commander.js學習,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09