1. 程式人生 > 資料庫 >MongoDB用Mongoose得到的物件不能增加屬性完美解決方法(兩種)

MongoDB用Mongoose得到的物件不能增加屬性完美解決方法(兩種)

一,先定義了一個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');

二,在定義一個users(使用者)的models

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

上述兩個models的關係可以看出:一個使用者對應一個購物車(cartList),一個購物車有多個商品物件

現在我們來為使用者新增商品(我們預設是可以直接新增的)===>userDoc為登入後的使用者,我們為此使用者的購物車新增商品

我們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"
                    })
                  }
                })
              }
            }
          })

上述正常執行後,我們並沒有在使用者的購物車中看到productNum和checked, 其餘的屬性均被賦值。

這是為什麼呢?

因為Mongoose是個ODM (Object Document Mapper),類似於操作關係型資料庫使用的ORM(Object Relational Mapper),我們使用Mongoose取到的資料的結構是要依賴於我們定義的schema結構的。增加的屬性在(goods)schema中沒有定義,所以我們給goods臨時附加productNum和checked屬性是無效的。

在這裡需要說明一下,就是雖然我們給schema附加屬性,但是這只是實現能真正掛在該schema上,並沒有新增到schema中。比如上述的只是想實現在新增商品的時候,順便把productNum和checked的值賦給users表中。我們無須把屬性儲存到goods中。

結論:mongodb中使用mongoose取到的物件不能增加屬性。

解決方法一,

在schema中直接增加需要補充的屬性。

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

這樣兩邊可以對等實現,賦值。(有時候不是很好)

解決方法二,

把查詢到的結果clone一個物件,然後在新物件中補充屬性。

 Goods.findOne({productId: productId},doc) {
            var newobj = null;//新物件
            if (err1) {
              return res.json({
                status: "1",msg: err1.message
              })
            } else {
              if (doc) {//商品
                newobj = {//新建立一個物件,實現轉換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",result: "suc"
                    })
                  }
                })
              }
            }
          })

執行之後,我們可以看到mongodb資料中的users表的procuctNum和checked被賦值。

總結

以上所述是小編給大家介紹的MongoDB用Mongoose得到的物件不能增加屬性完美解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回覆大家的。在此也非常感謝大家對我們網站的支援!