mongoose添加屬性問題

来源:https://www.cnblogs.com/ccyinghua/archive/2018/01/07/8232842.html
-Advertisement-
Play Games

在項目中遇到這樣一個問題。 項目地址: https://github.com/ccyinghua/vue-node-mongodb-project/blob/master/07-shoppingCart.md 有一個good商品模型(models/goods.js) 還有一個user用戶模型(mod ...


在項目中遇到這樣一個問題。

項目地址: https://github.com/ccyinghua/vue-node-mongodb-project/blob/master/07-shoppingCart.md

有一個good商品模型(models/goods.js)

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

// 定義一個Schema
var produtSchema = new Schema({
    'productId':String,   // 或者 'productId':{type:String}
    'productName':String,
    'salePrice':Number,
    'productImage':String
})

// 輸出(導出)
module.exports = mongoose.model('good',produtSchema);

還有一個user用戶模型(models/users.js)

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

// 定義一個Schema
var userSchema = new Schema({
    'userId':String,   // 或者 'userId':{type:String}
    'userName':String,
    'userPwd':String,
    'orderList':Array,
    'cartList':[           // 購物車列表
        {
            "productId":String,
            "productName":String,
            "salePrice":Number,
            "productImage":String,
            "checked":String,     // 是否選中
            "productNum":String  // 商品數量
        }
    ],
    "addressList":Array
})

// 輸出(導出)
module.exports = mongoose.model('user',userSchema);

現需要根據good模型中根據商品id獲取數據,然後添加到user的購物車列表中,實現加入購物車功能;

// 加入到購物車
var Goods = require('../models/goods');
var User = require('../models/users.js');  // 引入user模型
router.post("/addCart",function(req, res, next){
    var userId = '100000077',
        productId = req.body.productId;  // post請求拿到res參數:req.body

    // 查詢第一條:拿到用戶信息
    User.findOne({
        userId:userId   // 查詢條件
    },function(err,userDoc){
        if(err){
            res.json({
                status:"1",
                msg:err.message
            })
        }else{
            console.log("userDoc"+userDoc);  // 用戶數據
            if(userDoc){
                let goodsItem = '';
                userDoc.cartList.forEach(function(item){    // 遍歷用戶購物車,判斷加入購物車的商品是否已經存在
                    if(item.productId == productId){
                        goodsItem = item;
                        item.productNum++; // 購物車這件商品數量+1
                    }
                })
                if(goodsItem){  // 若購物車商品已存在
                    userDoc.save(function (err2,doc2) {
                        if(err2){
                            res.json({
                                status:"1",
                                msg:err2.message
                            })
                        }else{
                            res.json({
                                status:'0',
                                msg:'',
                                result:'suc'
                            })
                        }
                    })
                }else{   // 若購物車商品不存在,就添加進去
                    Goods.findOne({productId:productId},function(err1,doc){  // 從商品列表頁Goods查詢點擊加入購物車的那件商品信息
                        if(err1){
                            res.json({
                                status:"1",
                                msg:err1.message
                            })
                        }else{
                            if(doc){
                                doc.productNum = 1;
                                doc.checked = 1;
                                userDoc.cartList.push(doc);  // 添加信息到用戶購物車列表中
                                userDoc.save(function(err2,doc2){  // 保存資料庫
                                    if(err2){
                                        res.json({
                                            status:"1",
                                            msg:err2.message
                                        })
                                    }else{
                                        res.json({
                                            status:"0",
                                            msg:'',
                                            result:'suc'
                                        })
                                    }
                                })
                            }
                        }
                    })
                }
            }
        }
    })
})

在從mongodb的資料庫的goods表根據商品id獲取對應數據,再對此商品數據添加productNum和checked屬性,之後再插入到users表的購物車列表中;發現users表的購物車列表添加的商品信息沒有這兩個屬性。

 

 解決辦法一:

 在good模型內添加屬性是要在Schema添加這兩個屬性的;使用Mongoose取到的數據的結構是要依賴於定義的schema結構的。雖然我們給schema附加屬性,但是這隻是實現能真正掛在該schema上,並沒有添加到schema中。

var mongoose = require('mongoose');
var Schema = mongoose.Schema;

// 定義一個Schema
var produtSchema = new Schema({
    'productId':String,   // 或者 'productId':{type:String}
    'productName':String,
    'salePrice':Number,
    'productImage':String,

        // 添加的屬性 
       "checked":String,
       "productNum":Number
})

// 輸出(導出)
module.exports = mongoose.model('good',produtSchema); 

 解決辦法二:

新建一個對象,對象包含商品信息,添加到購物車列表。

var obj = null;
if(doc){
    obj = {
          productId: doc.productId,
          producName: doc.producName,
          salePrice: doc.salePrice,
          productName: doc.productName,
productImage: doc.productImage,
productNum:
1, checked: "1" } userDoc.cartList.push(obj); // 添加信息到用戶購物車列表中 userDoc.save(function(err2,doc2){ // 保存資料庫 if(err2){ res.json({ status:"1", msg:err2.message }) }else{ res.json({ status:"0", msg:'', result:'suc' }) } }) }

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • project文件不僅包含開發者指定的input信息,還包含很多其他輔助調試的input/output信息,算是嵌入式開發中承前啟後的文件。而本文側重點在於project文件中與開發者應用相關的input信息,僅當得到了這些input信息,再加上前面介紹的source和linker文件,那麼你就已經... ...
  • 這個技巧來自於我的實際開發碰到的: inet_addr這個函數用於把ip地址轉成網路位元組序,他的原型:in_addr_t inet_addr(const char *cp); 返回值為一個in_addr_t的類型,很顯然這不是一個c語言的標準數據類型,想搞清楚他到底是什麼類型,肯定要找到頭文件,在l ...
  • 這一系列的Linux入門都是本人在《鳥哥的Linux私房菜》的基礎上總結的基本內容,主要是記錄下自己的學習過程,也方便大家簡要的瞭解 Linux Distribution是Ubuntu而不是書本上推薦的CentOS,建議裝雙系統,不要使用虛擬機。 代碼在github上:Linuxpractice L ...
  • 因為項目計算量比較大,需要將任務分佈到多臺電腦上面運行,因為對於分散式概念不熟,就想到了linux最簡單的ssh協議,遠程式控制制其他電腦,然後寫shell腳本統一在所有電腦上運行程式.(我的操作系統為Ubuntu16.04) 首先在各自電腦上面輸入以下命令查看是否安裝了ssh ps -e | grep ...
  • 1、卸載原有系統中的yumrpm –qa | grep yum | xargs rpm -e --nodeps (xargs 把rpm –qa | grep yum傳來的每一行信息 都用xargs後面的命令進行處理) 2、創建一個目錄intallyum_mirrors.163.com,進入此目錄下載 ...
  • 1、使用yum install dnsmasq -y 安裝dns(含dns server和dns代理功能) 2、查詢dnsmasq已經安裝成功 [root@localhost ~]# rpm -q dnsmasq dnsmasq-2.48-18.el6_9.x86_64 [root@localhos ...
  • 1、查詢dhcp有沒有被安裝,如下沒有被安裝 [zfp@localhost ~]$ rpm -q dhcppackage dhcp is not installed[zfp@localhost ~]$ 2、查詢yum網路源中有關dhcp的rpm包 [root@localhost zfp]# yum ...
  • 1、執行Python腳本的兩種方式 2、簡述位、位元組的關係 3、簡述ascii、unicode、utf-­‐8、gbk的關係 4、請寫出 “朱銳” 分別用utf-­‐8和gbk編碼所占的位數 5、Pyhton單行註釋和多行註釋分別用什麼? 6、聲明變數註意事項有那些? 7、如有一下變數n1 = 5, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...