共计 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