NodeJs Express框架操作MongoDB數(shù)據(jù)庫(kù)執(zhí)行方法講解
1、Mongoose模塊
(1)是一個(gè)對(duì)象模型工具,是對(duì)Node.js環(huán)境下操作MongoDB數(shù)據(jù)庫(kù)進(jìn)行了封裝,可以將MongoDB數(shù)據(jù)庫(kù)中的數(shù)據(jù)轉(zhuǎn)換成JavaScript對(duì)象供用戶使用。
(2)名詞:
- Schema:它是一種以文件形式存儲(chǔ)的數(shù)據(jù)庫(kù)模型骨架,不具備對(duì)數(shù)據(jù)庫(kù)操作的能力,僅僅只是數(shù)據(jù)庫(kù)在程序片段中的一種表現(xiàn),可以理解為表結(jié)構(gòu)。
- Model:由Schema發(fā)布生成的模型,具有抽象屬性和行為的數(shù)據(jù)庫(kù)操作
- Entity:由Model創(chuàng)建的實(shí)體,它的操作也會(huì)影響數(shù)據(jù)庫(kù)
(3)命名規(guī)范:駝峰命名 例:
PersonSchema:Person對(duì)應(yīng)的Schema ,Person的文本屬性(表結(jié)構(gòu))
PersonModel:Person對(duì)應(yīng)的Model
PersonEntity:Person對(duì)應(yīng)的Entity
Schema生成Model,由Model生成Entity,Model和Entity都可以操作數(shù)據(jù)庫(kù),Model的可操作性更強(qiáng)。
2、Mongoose模塊的使用
(1)安裝:npm install mongoose
(2)創(chuàng)建數(shù)據(jù)庫(kù)連接文件
// 導(dǎo)入mongoose模塊
const Mongoose = require('mongoose');
// 定義MongoDB數(shù)據(jù)庫(kù)的連接字符串:協(xié)議://主機(jī)地址:端口號(hào)/數(shù)據(jù)庫(kù)名
const mdb_url = 'mongodb://localhost:27017/my_test';
/*
建立和MongoDB數(shù)據(jù)庫(kù)的連接
useNewUrlParser:是否使用新的url地址轉(zhuǎn)換方式
useUnifiedTopology:是否使用新的用戶安全策略
*/
Mongoose.connect(mdb_url,{useNewUrlParser:true,useUnifiedTopology:true});
// 對(duì)連接過(guò)程進(jìn)行處理
// 建立連接 ——連接成功觸發(fā)connected事件
Mongoose.connection.on('connected',()=>{
console.log('數(shù)據(jù)庫(kù)連接成功~'+mdb_url);
})
// 連接異常 ——回調(diào)函數(shù)的參數(shù)中保存了異常的信息
Mongoose.connection.on('error',(e)=>{
console.log(e);
})
//斷開(kāi)連接 ——斷開(kāi)連接觸發(fā)
Mongoose.connection.on('disconnected',()=>{
console.log('斷開(kāi)數(shù)據(jù)庫(kù)的連接~');
})
// 導(dǎo)出mongoose
module.exports = Mongoose;(3)創(chuàng)建Schema,再由Schema創(chuàng)建Model
- Schema:定義的是與集合對(duì)應(yīng)的骨架。Schema中的屬性對(duì)應(yīng)的是MongoDB中集合的key。
- 是Schema的實(shí)例,用于操作MongoDB中的集合中的文檔。
3、關(guān)于模型名稱和數(shù)據(jù)庫(kù)中集合名稱的對(duì)應(yīng)關(guān)系
(1)數(shù)據(jù)庫(kù)中沒(méi)有集合
mongoose.model('Admin',AdminSchema) ——>在模型名后加s就是集合名(不區(qū)分大小寫(xiě)) ——admins
mongoose.model('Admin',AdminSchema,'admin')——>第三個(gè)參數(shù)就是用于定義的集合名稱
(2)數(shù)據(jù)庫(kù)中有集合
mongoose.model('Admin',AdminSchema,'數(shù)據(jù)庫(kù)中已有的集合名')
4、mongoose的基本操作
(1)插入文檔:save方法
- 先使用Model創(chuàng)建Entity
- 然后使用Entity調(diào)用save方法
const AdminModel = require('../model/adminModel');
// 通過(guò)model創(chuàng)建一個(gè)對(duì)象
const admin = new AdminModel({
_id:'1005',
userName:'唐僧',
password:'123456',
address:'東土大唐'
})
/*
* 通過(guò)對(duì)象調(diào)用save方法向數(shù)據(jù)庫(kù)中插入數(shù)據(jù)err存放的是保存失敗后的信息 res是保存的對(duì)象
*/
admin.save((err,res)=>{
if(err){
console.log(err);
}else{
console.log(res);
}
})(2)刪除文檔:findByIdAndDelete :直接通過(guò)Model調(diào)用,作用是根據(jù)文檔的_id屬性刪除
(3)刪除文檔:deleteOne:直接通過(guò)Model調(diào)用,根據(jù)給定的條件刪除文檔
(4)更新文檔:findOneAndUpdate,直接通過(guò)Model調(diào)用
findOneAndUpdate(條件,更新語(yǔ)句,{},回調(diào)函數(shù))
AdminModel.findOneAndUpdate(
{'_id':'1004'}, //表示查詢的條件
{$set:{'password':'789567'}}, //更新語(yǔ)句
null, //表示查詢操作,通常為null
(err,data)=>{ //更新回調(diào)函數(shù),err表示數(shù)據(jù)庫(kù)的錯(cuò)誤信息,data中存放的findOne查詢到的文檔
if(err){
console.log(err); //err表示數(shù)據(jù)庫(kù)錯(cuò)誤:查詢、更新時(shí)數(shù)據(jù)庫(kù)出現(xiàn)異常
}else if(!data){ //data為null時(shí)表示沒(méi)有找到對(duì)應(yīng)的文檔
console.log('更新失敗~');
}else if(data){ //data不為null時(shí)表示找到對(duì)應(yīng)的文檔
console.log('更新成功~')
}
})(5)更新文檔:updateOne(條件,更新語(yǔ)句,回調(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:'三國(guó)',
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ù)庫(kù)執(zhí)行方法講解的文章就介紹到這了,更多相關(guān)NodeJs操作MongoDB數(shù)據(jù)庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- node.js+express+mySQL+ejs+bootstrop實(shí)現(xiàn)網(wǎng)站登錄注冊(cè)功能
- node.js平臺(tái)下利用cookie實(shí)現(xiàn)記住密碼登陸(Express+Ejs+Mysql)
- 零基礎(chǔ)搭建Node.js、Express、Ejs、Mongodb服務(wù)器及應(yīng)用開(kāi)發(fā)入門(mén)
- express框架通過(guò)ejs模板渲染輸出頁(yè)面實(shí)例分析
- Express 框架中使用 EJS 模板引擎并結(jié)合 silly-datetime 庫(kù)進(jìn)行日期格式化的實(shí)現(xiàn)方法
- nodejs中的express-jwt的使用解讀
- NodeJS?Express使用ORM模型訪問(wèn)關(guān)系型數(shù)據(jù)庫(kù)流程詳解
- NodeJs?Express路由使用流程解析
- NodeJs Express中間件使用流程解析
- express框架+bootstrap美化ejs模板實(shí)例分析
相關(guān)文章
Node.js中Express框架使用axios同步請(qǐng)求(async+await)實(shí)現(xiàn)方法
這篇文章主要介紹了Node.js中Express框架使用axios同步請(qǐng)求(async+await)實(shí)現(xiàn)方法,結(jié)合實(shí)例形式分析了express框架使用異步交互axios模塊實(shí)現(xiàn)同步請(qǐng)求的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2023-04-04
Node.js中readline模塊實(shí)現(xiàn)終端輸入
本文主要介紹了Node.js中readline模塊實(shí)現(xiàn)終端輸入,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
Node.js實(shí)現(xiàn)一個(gè)HTTP服務(wù)器的方法示例
這篇文章主要介紹了Node.js實(shí)現(xiàn)一個(gè)HTTP服務(wù)器的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05
簡(jiǎn)單易懂的nvm和Node.js版本控制的實(shí)現(xiàn)
NVM是Node.js的版本管理工具,可以方便地在不同版本的Node.js之間切換,本文主要介紹了簡(jiǎn)單易懂的nvm和Node.js版本控制的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10
如何使用Node.js爬取任意網(wǎng)頁(yè)資源并輸出PDF文件到本地
這篇文章主要介紹了使用Node.js爬取任意網(wǎng)頁(yè)資源并輸出高質(zhì)量PDF文件到本地,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,下面小編就來(lái)和大家一起學(xué)習(xí)吧2019-06-06
防止Node.js中錯(cuò)誤導(dǎo)致進(jìn)程阻塞的辦法
Node.js我們用到非常的多了,如果我們開(kāi)發(fā)不當(dāng)可能因錯(cuò)誤導(dǎo)致進(jìn)程阻塞問(wèn)題,對(duì)于進(jìn)程阻塞問(wèn)題一直是個(gè)頭痛的事情,今天我們一起來(lái)看一篇關(guān)于Node.js防止錯(cuò)誤導(dǎo)致的進(jìn)程阻塞示例,下面一起來(lái)看看。2016-08-08
node.js中實(shí)現(xiàn)token的生成與驗(yàn)證的操作方法
Token是一種用于在客戶端和服務(wù)器之間安全傳輸信息的加密字符串,常用于身份驗(yàn)證、授權(quán)、狀態(tài)管理和安全性,在Node.js中,常用jsonwebtoken庫(kù)生成和驗(yàn)證Token,本文介紹node.js中實(shí)現(xiàn)token的生成與驗(yàn)證的操作方法,感興趣的朋友一起看看吧2025-01-01
Nodejs實(shí)現(xiàn)WebSocket代碼實(shí)例
這篇文章主要介紹了Nodejs實(shí)現(xiàn)WebSocket代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05

