欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

NodeJs Express框架操作MongoDB數(shù)據(jù)庫執(zhí)行方法講解

 更新時(shí)間:2023年01月10日 15:54:53   作者:禿頭小宋s  
MongoDB是一個(gè)介于關(guān)系數(shù)據(jù)庫和非關(guān)系數(shù)據(jù)庫之間的產(chǎn)品,是非關(guān)系數(shù)據(jù)庫當(dāng)中功能最豐富,最像關(guān)系數(shù)據(jù)庫的。他支持的數(shù)據(jù)結(jié)構(gòu)非常松散,是類似json的bjson格式,因此可以存儲比較復(fù)雜的數(shù)據(jù)類型

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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論