mongodb用mongoose得到的对象不能增加属性解决

Posted 与你在巅峰相会

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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,
            "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得到的对象不能增加属性解决的主要内容,如果未能解决你的问题,请参考以下文章

mongodb用mongoose查库的对象,不能增加属性

找不到 id 并更新和增加子文档 - 返回 null Mongoose/mongoDB

用 Javascript 中的键值对重构对象数组并输出或发出它以用 mongoose 和 MongoDB 保存它?

无法使用 mongoose 在 mongodb 中增加字段

关于NodeJs为啥要用mongoose操作mongodb

Mongoose + MongoDB - 尝试使用 POSTMAN 保存后,转换为 ObjectID 的值失败