• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

MongoDB用Mongoose得到的对象不能增加属性完美解决方法(两种)

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一,先定义了一个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,
      "producName": String,
      "salePrice":Number,
      "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,
  "producName": String,
  "salePrice":Number,
  "productImage":String
  "checked": String,
  "productNum": String
});
module.exports=mongoose.model("Good",productSchema,'goods');

这样两边可以对等实现,赋值。(有时候不是很好)

解决方法二,

把查询到的结果clone一个对象,然后在新对象中补充属性。

 Goods.findOne({productId: productId}, function (err1, 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",
                      msg: err2.message
                    })
                  } else {
                    return res.json({
                      status: "0",
                      msg: '',
                      result: "suc"
                    })
                  }
                })
              }
            }
          })

执行之后,我们可以看到mongodb数据中的users表的procuctNum和checked被赋值。

总结

以上所述是小编给大家介绍的MongoDB用Mongoose得到的对象不能增加属性完美解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对极客世界网站的支持!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
MySQL数据操作-DML语句的使用发布时间:2022-02-08
下一篇:
oralce和db2兼容开发注意事项发布时间:2022-02-08
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap