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