阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

MongoDB用Mongoose得到的对象不能增加属性解决

221次阅读
没有评论

共计 3275 个字符,预计需要花费 9 分钟才能阅读完成。

一,先定义了一个 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 相关教程见以下内容

MongoDB 文档、集合、数据库简介  http://www.linuxidc.com/Linux/2016-12/138529.htm

MongoDB 3 分片部署及故障模拟验证  http://www.linuxidc.com/Linux/2016-12/138529.htm

Linux CentOS 6.5 yum 安装 MongoDB  http://www.linuxidc.com/Linux/2016-12/137790.htm

CentOS 7 yum 方式快速安装 MongoDB  http://www.linuxidc.com/Linux/2016-11/137679.htm

MongoDB 的查询操作  http://www.linuxidc.com/Linux/2016-10/136581.htm

在 Azure 虚拟机上快速搭建 MongoDB 集群  http://www.linuxidc.com/Linux/2017-09/146778.htm

MongoDB 复制集原理  http://www.linuxidc.com/Linux/2017-09/146670.htm

MongoDB 3.4 远程连接认证失败  http://www.linuxidc.com/Linux/2017-06/145070.htm

Ubuntu 16.04 中安装 MongoDB3.4 数据库系统  http://www.linuxidc.com/Linux/2017-07/145526.htm

MongoDB 权威指南第 2 版 PDF 完整带书签目录 下载见 http://www.linuxidc.com/Linux/2016-12/138253.htm

MongoDB 的详细介绍:请点这里
MongoDB 的下载地址:请点这里

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-11/148920.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计3275字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中