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得到的对象不能增加属性完美解决方法,希望对大家有所帮助