我想在mongodb中搜索一个嵌入文档,只返回我想要的内容。这是文件:
"_id" : "yH8HmCPz6H6E8Hinq",
"between" : [
"4bgdLrztpqgwAkZP4",
"9jZhXHjAkoY7mmX7B"
],
"messages" : [
{
"content" : "fdsqf",
"user" : "4bgdLrztpqgwAkZP4",
"created_at" : ISODate("2016-11-17T23:13:59.659Z"),
"isSeen" : false,
"sender" : "John doe",
"receiver" : "Elen doe"
},
{
"content" : "test",
"user" : "9jZhXHjAkoY7mmX7B",
"created_at" : ISODate("2016-11-20T11:42:42.893Z"),
"isSeen" : false,
"sender" : "Elen doe",
"receiver" : "John doe"
}
]我想要的是"messages.isSeen“等于false,而接收方不是Meteor.user().username。
最后,如何将该字段更新为真。
希望有人能帮忙!提前谢谢!
发布于 2016-11-21 02:00:09
您需要在查询中包括_id,在更新中包括$set。
let id = "yH8HmCPz6H6E8Hinq";
let username = Meteor.user().username;
let query = { _id: id, messages: { $elemMatch: { isSeen: false, receiver: { $ne: username }}}};
Chat.update(query,{ $set: { "messages.$.isSeen": true }});发布于 2016-11-20 17:42:04
你需要这样的东西:
Chat.update({
'messages.isSeen': false, // isSeen is false
'messages.receiver': { // Receiver is
$ne: Meteor.user().username // not equal to Meteor.user().username
}
}, {
'messages.$isSeen': true // Set isSeen to true
});https://stackoverflow.com/questions/40706211
复制相似问题