- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
这是文档的结构。
{
"_id" : ObjectId("5548f1cc0dcd6bd925a71ae2"), //document id
"messages" : [
{
"subject" : "NEW ++ SUBJECT",
"from" : ObjectId("5534b2992a104ed914435c31"),
"_id" : ObjectId("5548f1cc0dcd6bd925a71ae3"),
"created" : ISODate("2015-05-05T16:37:32.832Z"),
"read" : false,
"message" : "FIRST MESSAGE",
"participants" : [
ObjectId("5534b2992a104ed914435c31"),
ObjectId("5530af38576214dd3553331c")
]
},
{
"subject" : "dfgsd",
"from" : ObjectId("5534b2992a104ed914435c98"),//logged In USer
"_id" : ObjectId("5548f1df0dcd6bd925a71ae4"),
"created" : ISODate("2015-05-05T16:37:51.455Z"),
"read" : false,
"message" : "rdfgdgfd",
"participants" : [
ObjectId("5534b2992a104ed914435c98"),//logged In USer
ObjectId("5530af38576214dd3553331c")
]
}
"participants" : [
ObjectId("5534b2992a104ed914435c98"),//logged In USer
ObjectId("5534b2992a104ed914435c31"),
ObjectId("5530af38576214dd3553331c")
],
"__v" : 3
}
我想获取消息数组的消息对象,其“读取”值为“假”且“来自”不等于登录用户(此处登录用户为5534b2992a104ed914435c98)。并且文档的“参与者”数组必须包含登录的用户 ID (5534b2992a104ed914435c98)。这是我尝试过的查询。
db.conversations.find({participants:ObjectId('5534b2992a104ed914435c98'),'messages.read':false,'messages.from':{$ne:ObjectId('5534b2992a104ed914435c98')}}).pretty().
基本上我正在尝试获取未读消息的数量。我对 mongodb/mongoose 很陌生。如果您发现问题中有错误,请纠正我。
最佳答案
如果您尝试根据以下条件获取未读消息的数量:“read”值为“false”且“from”不等于登录用户(此处登录用户为 5534b2992a104ed914435c98
),并且文档的 'participants'
数组必须包含登录用户 ID 5534b2 992a104ed914435c98
,然后是aggregation framework 方法应该可以帮助您获得所需的结果。
聚合管道应具有第一个管道阶段 $match
满足上述条件的查询。这会过滤出需要在管道流中进一步处理的文档。
对于不使用 $unwind
的解决方案运算符在处理之前首先展平消息数组,请考虑 $filter
和 $size
运算符如下:
var pipeline = [
{
"$match": {
"participants": ObjectId("5534b2992a104ed914435c98"),
"messages.read" : false,
"messages.from" : { "$ne": ObjectId('5534b2992a104ed914435c98') }
}
},
{
"$project": {
"_id": 0,
"unread_messages": {
"$size": {
"$filter": {
"input": "$messages",
"as": "msg",
"cond": {
"$and": [
{ "$not": [ "$$msg.read" ] },
{ "$ne": ["$$msg.from", ObjectId('5534b2992a104ed914435c98')]}
]
}
}
}
}
}
}
]
db.conversations.aggregate(pipeline)
如果您使用的驱动程序不支持上述运算符,请考虑在 $match
之后设置下一个管道阶段。作为$unwind
该操作用于解构 messages
数组,以便您可以为每个元素输出一个文档。
使用$match
进一步过滤需要对解构的消息使用运算符,以仅允许那些满足先前条件的消息在管道中进一步处理。
这一步操作对于下一个管道阶段($group
)是必需的。运算符,它按指定的标识符表达式对传入文档进行分组并应用 $sum
累加器表达式到每个组,以便您可以获得该组中的文档总数。
最后一个阶段使用 $project
运算符通过抑制 _id 字段来 reshape 流中的最终结果文档,并添加一个新字段 unread_messages
,该字段描述 read
字段值为 false 的消息总数。
最终的聚合管道如下所示:
var pipeline = [
{
"$match": {
"participants": ObjectId("5534b2992a104ed914435c98"),
"messages.read" : false,
"messages.from" : { "$ne": ObjectId('5534b2992a104ed914435c98') }
}
},
{
"$unwind": "$messages"
},
{
"$match": {
"participants": ObjectId("5534b2992a104ed914435c98"),
"messages.read" : false,
"messages.from" : { "$ne": ObjectId('5534b2992a104ed914435c98') }
}
},
{
"$group": {
"_id": null,
"count": {
"$sum": 1
}
}
},
{
"$project": {
"_id": 0,
"unread_messages": "$count"
}
}
]
您可以在 Mongoose 聚合中使用它,如下所示:
Conversations.aggregate(pipeline, function (err, res) {
if (err) return handleError(err);
console.log(res); // [ { unread_messages: 34 } ] <-- this is a made up value :-)
});)
或者使用聚合管道构建器:
Conversations.aggregate()
.match({
"participants": ObjectId("5534b2992a104ed914435c98"),
"messages.read" : false,
"messages.from" : { "$ne": ObjectId('5534b2992a104ed914435c98') }
})
.unwind("messages")
.match({
"participants": ObjectId("5534b2992a104ed914435c98"),
"messages.read" : false,
"messages.from" : { "$ne": ObjectId('5534b2992a104ed914435c98') }
})
.group({ "_id": null, "unread_messages": { "$sum": 1 } })
.select("-id unread_messages")
.exec(function (err, res) {
if (err) return handleError(err);
console.log(res); // [ { unread_messages: 34 } ] <-- this is a made up value :-)
});
关于node.js - 如何在 mongoose/mongodb 中使用不等于运算符?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30058941/
当我保存4条记录时,我需要将它们一一保存,所以我的代码是 a.save(function(){ b.save(function(){ c.save(function(){ d.save(f
Mongoose在版本4.2.7中创建了一个新的单个子文档功能(documentation和feature request),允许使用单个嵌入式子文档架构,其行为方式与一对多子文档的行为相同。 在父级
Mongoose 版本 >= 4.0 有一个时间戳选项,当 timestamps 设置为 时,该选项会为架构创建 updatedAt 和 createdAt 字段正确。 http://mongoose
我注意到某些图书馆喜欢 mock 鹅 ( https://github.com/mccormicka/Mockgoose/blob/master/test/index.spec.js ) 使用 req
我正在与 Mongoose 合作。我见过很多开发者发出以下命令: mongoose.Promise = global.Promise; 然后我很好奇 mongoose.Promise 的原始值是什么。
当我运行与数据库大量连接和断开连接的测试时,我收到以下警告。 (node) warning: possible EventEmitter memory leak detected. 11 connec
我可以在 Mongoose 的子文档数组中填充动态引用(使用“refPath”)虚拟字段吗? 数据结构如下 Group - Members -> User 代码:模型/模式 let MemberSc
我正在我的应用程序中做一些测试,看看内存缓存是否真的在工作。但是,由于 memory-cache 显然没有公开“命中”事件,我无法判断是否真的从缓存中获取数据。所以我试着看看当应用程序实际从数据库中获
我是 nestjs 的新手。我使用 @nestjs/mongoose,我需要在我的类模式中引用嵌套对象中的几个字段,但我不知道该怎么做。 dietDays 对象必须包含一个日期字段和包含对 Meal
我是 mongodb 的新手,我有一个这样的数据模型 { last_updated: Date.now(), csgo_items:[ {name: 'name', p
这是我的方案: var documentSchema = mongoose.Schema({ 'facts': [{ 'type': { type: String, requi
我想删除多个 _ids = ['123', '234', '345']; _ids.forEach(_id => { await model.deleteOne({ _id }); }); 有没有
我有一个像这样的 Mongoose 模式: var Address = { doorNo:String, city:String, state:String, coun
我的文档包含一个名为 clients 的字段那应该包含一组客户端ID。 { "first_name":"Nick", "last_name":"Parsons", "email":"nic
我遇到了以下我无法理解的代码行,尽管有很多教程提供了与 populate 的示例相关的信息。但没有一个能解释它究竟意味着什么。这是一个例子 var mongoose = require('mongoo
我有一个具有多个唯一性的架构,如下所示: var userSchema = new mongoose.Schema({ user: { type: String, unique:
我有一个 Mongoose 模式,其中有 4 个子模式。我一直在关注这里的文档https://github.com/LearnBoost/mongoose关于嵌入文档 var scenarios =
我希望每个字符串属性都默认设置为 true。有办法吗? ?? mongoose.Schema.String -> default { trim: true } var schema = new Sch
我有这个代码 var ClientSchema = new Schema({ name: {type: String, required: true, trim: true} }); var Cl
许多教程告诉您在您的 userSchema 页面中使用 bycrypt。保存新用户后,它会附带加密密码。伟大的。然而,我想,当我用某些东西编辑用户时,它也会重新哈希密码,导致无法登录。你能给我一个解决
我是一名优秀的程序员,十分优秀!