中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在node.js中使用mongoose對數據庫進行操作

發布時間:2021-03-22 17:26:15 來源:億速云 閱讀:220 作者:Leah 欄目:web開發

本篇文章為大家展示了怎么在node.js中使用mongoose對數據庫進行操作,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。

1、數據庫操作語句

Mongoose通過model實現對每個集合的操作,在使用前需要先定義model:goods。

①、增加數據:從集合中查詢一條記錄,并返回doc,對doc操作之后通過save()保存到集合

goods.findOne({productId},(err,goodsDoc)=>{
   goodsDoc.productNum=1;
   goodsDoc.save(err,doc);
});

②、刪除數據:

model.remove(conditions,callback(){})

③、修改數據:

model.update(conditions,updates,callback(){})

④、查詢數據:

model.find(conditions,callback(){})

2、添加購物車

mongodb中新建用戶user集合,user中有cartList數組,用戶點擊添加購物車時在前端發出post請求包括用戶、商品的id。然后在后端查詢到對應的用戶,將其cartList中的商品id進行比對,如果在其中,則把商品數量+1,否則從商品集合中查詢商品信息,插入到cartList數組中。

前端添加購物車請求:

  addCart(productId){//加入購物車
   axios.post('./users/addCart',{
    userId:"100000077",
    productId:productId
   }).then((response)=>{
    let res=response.data;
    console.log(res.msg);
   });
  }

后端處理:

var express = require('express');
var router = express.Router();
const mongoose=require('mongoose');
var user=require('../models/userModel');
var goods=require('../models/productModel');
//連接數據庫
mongoose.connect('mongodb://localhost:27017/mall');
mongoose.connection.on('connected',()=>{
 console.log("mongoDB連接成功");
});
//處理添加購物車請求
router.post('/addCart',(req,res,next)=>{
 let userId=req.body.userId;
 let productId=req.body.productId;
 let params={
  userId
 };
 user.findOne(params,(err,userDoc)=>{//查詢對應用戶信息
  if (err){
   res.json({
    status:1,
    msg:err.message
   });
  }else{
   if(userDoc){
    let inCart=false;
    userDoc.cartList.forEach(function(item){//遍歷cartList比對商品id
     if (item.productId==productId){    //若商品在購物車內,數量增加
      inCart=true;
      item.productNum++;
      saveDoc(userDoc,res);
     }
    });
    //所選商品不在購物車內,則從商品列表內查找并添加到購物車
    if(!inCart){
     goods.findOne({productId},(err,goodsDoc)=>{
      if(err){
       res.json({
        status:1,
        msg:err.message
       })
      }else{
       goodsDoc.checked=true;
       goodsDoc.productNum=1;
       userDoc.cartList.push(goodsDoc);//將商品插入到用戶cartList數組內
       console.log(userDoc.cartList);
       saveDoc(userDoc,res);
      }
     });
    }
   }
  }
 })
});

利用doc.save將修改后的文檔保存到數據庫

function saveDoc(doc,res) {
 //保存操作
 doc.save((err,doc)=>{
  if (err){
   res.json({
    status:1,
    msg:err.message
   })
  }else {
   res.json({
    status:0,
    msg:"添加購物車成功",
    result:'success'
   })
  }
 })
}

3、從購物車刪除數據

前端點擊刪除按鈕,調用deleteCart()發出post請求,刪除成功重新加載購物車列表

   deleteCart(){
    axios.post('users/deleteCart',{
     productId:this.productId
    }).then((response,err)=>{
     let res=response.data;
     if(res.status===0){
      this.getCart();
      this.modalShow=false;
     }
    })
   },

后端獲取到刪除商品的id、用戶的id,刪除數據庫中指定條目

router.post('/deleteCart',(req,res)=>{
 "use strict";
 let productId=req.body.productId;
 let userId=req.cookies.userId;
 user.update({userId:userId},{
  $pull:{
   cartList:{productId:productId}
  }
 },(err,doc)=>{
  if(err){
   res.json({
    status:1,
    msg:'數據庫刪除失敗'
   })
  }else{
   if(doc){
    res.json({
     status:0,
     msg:'購物車刪除成功'
    })
   }
  }
 })
});

4、修改購物車

前端對不同的按鈕點擊,實現購物車數量的增、減、選中的改變,調用editCart(opt,item),然后將修改的數據以post發送

editCart(flag,item){
    if(flag==='check'){
     item.checked=!item.checked;
    }else if(flag==='add'){
     item.productNum++;
    }else if(flag==='sub'){
     item.productNum<=0 ? item.productNum=0 : item.productNum++ ;
    }
    axios.post('users/editCart',{
     productId:item.productId,
     checked:item.checked,
     productNum:item.productNum
    }).then((response,err)=>{
     let res=response.data;
     if(res.status===0){
      this.getCart();
     }else{
      console.log(res.msg);
     }
    })
}

后端接收要修改的數據,并對數據庫進行更新:

router.post('/editCart',(req,res)=>{
 "use strict";
 let productId=req.body.productId;
 let checked=req.body.checked;
 let productNum=req.body.productNum;
 let userId=req.cookies.userId;
 user.update({userId:userId,'cartList.productId':productId},{
  $set:{"cartList.$.checked":checked,"cartList.$.productNum":productNum}
 },(err,doc)=>{
  if(err){
   res.json({
    status:1,
    msg:err.message
   })
  }else {
   res.json({
    status:0,
    msg:'購物車更新成功'
   })
  }
 })
});

5、查詢購物車

前端發送查詢購物車get請求,將結果數據賦予catList,頁面遍歷cartList渲染數據

   getCart(){
    axios.get('users/getCart').then((response,err)=>{
     let res=response.data;
     if(res.status===0){
      this.cartList=res.result.list;
     }else{
      console.log(res.msg);
     }
    })
   },

后端根據用戶的cookie,查詢指定的用戶的購物車

router.get('/getCart',(req,res)=>{
 "use strict";
 user.findOne({userId:req.cookies.userId},(err,doc)=>{
  if(doc){
   res.json({
    status:0,
    msg:'',
    result:{
     list:doc.cartList
    }
   })
  }else{
   res.json({
    status:1,
    msg:"購物車列表查詢失敗"
   })
  }
 })
});

6、購物車的總價與全選

利用vue的計算屬性可以實現屬性的隨時變化,計算屬性只有在相關數據發送改變時才會隨之改變,計算屬性的實現像函數,但使用類似于一般屬性,例如總價totalPrice與判斷是否全部選中allSelected:

  computed:{
   totalPrice(){
    let total=0;
    this.cartList.forEach((item)=>{
     if(item.checked)
      total+=parseFloat(item.salePrice)*parseInt(item.productNum);
    });
    return total;
   },
   allSelected(){
    let selected=true;
    this.cartList.forEach((item)=>{
     selected=selected&&item.checked;
    });
    console.log(selected);
    return selected;
   }
  },

上述內容就是怎么在node.js中使用mongoose對數據庫進行操作,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

马鞍山市| 林州市| 蒙城县| 钟祥市| 耒阳市| 收藏| 华安县| 沙坪坝区| 曲沃县| 蓬溪县| 富川| 彭泽县| 涞源县| 秭归县| 泸西县| 临漳县| 齐齐哈尔市| 丹江口市| 扶沟县| 南充市| 博罗县| 利津县| 潞城市| 阳泉市| 防城港市| 来凤县| 新乐市| 甘肃省| 丹巴县| 监利县| 杭锦后旗| 红原县| 巴马| 将乐县| 崇左市| 琼中| 衡山县| 库车县| 霍林郭勒市| 田东县| 沐川县|