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

MongoDB用Mongoose得到的對(duì)象不能增加屬性完美解決方法(兩種)

 更新時(shí)間:2017年11月28日 11:08:03   投稿:mrr  
本文給大家分享兩種解決方案解決MongoDB用Mongoose得到的對(duì)象不能增加屬性問題,本文給大家介紹的非常詳細(xì),需要的朋友參考下吧

一,先定義了一個(gè)goods(商品)的models

var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var productSchema = new Schema({
  "productId":String,
  "producName": String,
  "salePrice":Number,
  "productImage":String
});
module.exports=mongoose.model("Good",productSchema,'goods');

二,在定義一個(gè)users(用戶)的models

var mongoose = require('mongoose');
var userSchema = new mongoose.Schema({
  "userId": String,
  "userName": String,
  "userPwd": String,
  "orderList": Array,
  "cartList": [
    {
      "productId":String,
      "producName": String,
      "salePrice":Number,
      "productName": String,
      "productImage": String,
      "checked": String,
      "productNum": String
    }
  ],
  "addressList": Array
});
module.exports = mongoose.model("User", userSchema, 'users')
/*commonjs規(guī)范*/

上述兩個(gè)models的關(guān)系可以看出:一個(gè)用戶對(duì)應(yīng)一個(gè)購物車(cartList),一個(gè)購物車有多個(gè)商品對(duì)象

現(xiàn)在我們來為用戶添加商品(我們默認(rèn)是可以直接添加的)===>userDoc為登錄后的用戶,我們?yōu)榇擞脩舻馁徫镘囂砑由唐?/p>

我們goods路由中:

Goods.findOne({
            productId: productId
          }, function (err1, doc) {
            
            if (err1) {
              return res.json({
                status: "1",
                msg: err1.message
              })
            } else {
              if (doc) {//商品

                 doc.productNum="1",
                  doc.checked="1",

                userDoc.cartList.push(doc);
                userDoc.save(function (err2) {
                  if (err2) {
                    return res.json({
                      status: "1",
                      msg: err2.message
                    })
                  } else {
                    return res.json({
                      status: "0",
                      msg: '',
                      result: "suc"
                    })
                  }
                })
              }
            }
          })

上述正常執(zhí)行后,我們并沒有在用戶的購物車中看到productNum和checked, 其余的屬性均被賦值。

這是為什么呢?

因?yàn)镸ongoose是個(gè)ODM (Object Document Mapper),類似于操作關(guān)系型數(shù)據(jù)庫使用的ORM(Object Relational Mapper),我們使用Mongoose取到的數(shù)據(jù)的結(jié)構(gòu)是要依賴于我們定義的schema結(jié)構(gòu)的。增加的屬性在(goods)schema中沒有定義,所以我們給goods臨時(shí)附加productNum和checked屬性是無效的。

在這里需要說明一下,就是雖然我們給schema附加屬性,但是這只是實(shí)現(xiàn)能真正掛在該schema上,并沒有添加到schema中。比如上述的只是想實(shí)現(xiàn)在添加商品的時(shí)候,順便把productNum和checked的值賦給users表中。我們無須把屬性存儲(chǔ)到goods中。

結(jié)論:mongodb中使用mongoose取到的對(duì)象不能增加屬性。

解決方法一,

在schema中直接增加需要補(bǔ)充的屬性。

var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var productSchema = new Schema({
  "productId":String,
  "producName": String,
  "salePrice":Number,
  "productImage":String
  "checked": String,
  "productNum": String
});
module.exports=mongoose.model("Good",productSchema,'goods');

這樣兩邊可以對(duì)等實(shí)現(xiàn),賦值。(有時(shí)候不是很好)

解決方法二,

把查詢到的結(jié)果clone一個(gè)對(duì)象,然后在新對(duì)象中補(bǔ)充屬性。

 Goods.findOne({productId: productId}, function (err1, doc) {
            var newobj = null;//新對(duì)象
            if (err1) {
              return res.json({
                status: "1",
                msg: err1.message
              })
            } else {
              if (doc) {//商品
                newobj = {//新創(chuàng)建一個(gè)對(duì)象,實(shí)現(xiàn)轉(zhuǎn)換mongoose不能直接增加屬性的坑
                  productNum: "1",
                  checked: "1",
                  productId: doc.productId,
                  producName: doc.producName,
                  salePrice: doc.salePrice,
                  productName: doc.productName,
                  productImage: doc.productImage,
                }
                userDoc.cartList.push(newobj);
                userDoc.save(function (err2) {
                  if (err2) {
                    return res.json({
                      status: "1",
                      msg: err2.message
                    })
                  } else {
                    return res.json({
                      status: "0",
                      msg: '',
                      result: "suc"
                    })
                  }
                })
              }
            }
          })

執(zhí)行之后,我們可以看到mongodb數(shù)據(jù)中的users表的procuctNum和checked被賦值。

總結(jié)

以上所述是小編給大家介紹的MongoDB用Mongoose得到的對(duì)象不能增加屬性完美解決方法,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 使用mongoose和bcrypt實(shí)現(xiàn)用戶密碼加密的示例

    使用mongoose和bcrypt實(shí)現(xiàn)用戶密碼加密的示例

    下面小編就為大家分享一篇使用mongoose和bcrypt實(shí)現(xiàn)用戶密碼加密的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題

    Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題

    這篇文章主要介紹了Mongodb解決不能連接到服務(wù)器的錯(cuò)誤問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • MongoDB 學(xué)習(xí)筆記

    MongoDB 學(xué)習(xí)筆記

    最近在學(xué)習(xí)MongoDB,小結(jié)一下,主要都是一些基礎(chǔ)知識(shí),需要的朋友可以參考下
    2014-07-07
  • 2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫安裝及配置環(huán)境

    2021最新版windows10系統(tǒng)MongoDB數(shù)據(jù)庫安裝及配置環(huán)境

    這篇文章主要介紹了2021最新版MongoDB數(shù)據(jù)庫安裝及配置環(huán)境(windows10系統(tǒng)),本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • MongoDB集合中的文檔管理

    MongoDB集合中的文檔管理

    這篇文章介紹了MongoDB集合中文檔的管理方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • MongoDB mongoexport工具的使用簡介

    MongoDB mongoexport工具的使用簡介

    這篇文章主要介紹了MongoDB mongoexport工具的使用簡介,幫助大家更好的理解和學(xué)習(xí)使用MongoDB數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-03-03
  • Mongodb數(shù)據(jù)庫誤刪后的恢復(fù)方法(兩種)

    Mongodb數(shù)據(jù)庫誤刪后的恢復(fù)方法(兩種)

    本文給大家分享兩種方法來實(shí)現(xiàn)Mongodb數(shù)據(jù)庫誤刪后的恢復(fù),每種方法給大家介紹的都非常詳細(xì),需要的朋友參考下吧
    2018-08-08
  • mongos崩潰后無法重啟問題的解決方法

    mongos崩潰后無法重啟問題的解決方法

    這篇文章主要給大家介紹了關(guān)于mongos崩潰后無法重啟問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • MongoDB 刪除文檔的方式(刪除一個(gè)、批量刪除)

    MongoDB 刪除文檔的方式(刪除一個(gè)、批量刪除)

    這篇文章主要介紹了MongoDB 刪除文檔的方式(刪除一個(gè)、批量刪除),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • MongoDB快速入門筆記(四)之MongoDB查詢文檔操作實(shí)例代碼

    MongoDB快速入門筆記(四)之MongoDB查詢文檔操作實(shí)例代碼

    MongoDB 是一個(gè)基于分布式文件存儲(chǔ)的數(shù)據(jù)庫。接下來通過本文給大家介紹MongoDB快速入門筆記(四)之MongoDB查詢文檔操作實(shí)例代碼,感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06

最新評(píng)論