我有一个存储少数产品文档的集合。在文档中,有一个数组evaluation
来存储用户的对象'对产品的价格评估。
以下是用户对象的示例:
var data = {user_id:90,price:400}
任何人都可以告诉我是否可以执行"插入重复更新"在evaluation
数组?我尝试了$addToSet
,但当一个对象被推入evaluation
时,有一个_id
属性被添加到用户对象中,即使我没有将其添加到用户对象中模特,像这样:
{
"_id": 54b13f52604fc5d242d4aa68,
"__v": NumberInt(0),
"evaluation": [
{
"price": NumberInt(14616),
"user_id": NumberInt(91),
"_id": ObjectId("54b13f5e604fc5d242d4aa6b") // Why is it added?
},
{
"price": NumberInt(16211),
"user_id": NumberInt(92),
"_id": ObjectId("54b140d1604fc5d242d4aa74") //
}
],
"product": [
{
"title": "ABC",
"model_id": "382",
"id": "513",
"category": "1",
"src": "xxx.jpg"
}
],
"timestamp":ISODate("2015-01-10T15:03:46.310Z")
}
$addToSet
是如何使用id字段检查重复对象的?
model.js
var evaluation = new mongoose.Schema({
product:[],
timestamp : { type : Date, default: Date.now },
evaluation:[{user_id:Number,price:Number}],
},{strict:false});
var models = {
Eva:mongoose.model('Evaluation',evaluation)
};
app.js
var mongo_models = require('./db/mongo_model')(mongoose);
Eva = mongo_models.Eva;
io.on('connection', function(socket){
socket.on("evaluation",function(d){
var data = {user_id:user_id,price:d.price};
Eva.update({_id:d.tid},{$addToSet:{evaluation:data}}).exec();
})
})
答案 0 :(得分:4)
您可以通过声明元素的内联架构并禁用_id
来阻止Mongoose向evaluation
数组元素添加_id
字段:
var evaluation = new mongoose.Schema({
product:[],
timestamp : { type : Date, default: Date.now },
evaluation:[Schema({user_id:Number,price:Number}, {_id: false})],
},{strict:false});