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得到的对象不能增加属性完美解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对编程小技巧网站的支持! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- sqlserver 链接服务器 用远程表更新本地数据表失败
- sql – 在Oracle Query中生成每行中的随机数
- sql – INSERT操作是否会导致死锁?
- Sybase EAServer学习(一) 创建Ms SqlServer 连接池
- 用SQLyog和NativeSQL将数据从sqlserver导入到mysql
- MSSQLSERVER CAN NOT START AFTER ENABLE & DIABLE VIA
- sql-server – SQL Server Float数据类型计算与十进制
- dct问题解决日志
- 数据库 – 存储许多日志文件
- sqlserver和oracel的使用心得记录(语句技巧和错误解决)