[英]Mongoose NodeJS - Find the last inserted record per user
在NoSQL和Mongoose方面,我是个新手。 我一直在搜索,但无法真正找到我想要的东西(这使我更不知道答案的难度更大)。
基本上,我有一个由用户添加的记录列表。 这些记录包含一些数据,我想列出每个用户的最新插入消息列表。
在SQL中,我会写;
SELECT * FROM records ORDER BY inserted_date GROUP BY user_id;
这将返回一个这样的集合;
[
{user: 2, insert_date: 2015-08-12T15:15:00, message: "Hi"},
{user: 3, insert_date: 2015-08-12T15:12:00, message: "Also hi"},
{user: 5, insert_date: 2015-08-12T15:14:00, message: "Not hi"}
]
我一直在环顾四周,找到了一些答案,但这些似乎没有用。
我试过了;
https://stackoverflow.com/a/7570091/1493455
还有其他一些聚合的东西,就像这样;
Record.aggregate(
{},
{
$group: {
_id: '$user_id',
inserted: { $last: "$inserted" },
message: { $last: "$message" }
}
},
function(err, messages) {
console.log(err, messages);
}
);
我已经从另一个答案中复制了该内容-但我并不十分了解它在做什么,甚至应该做什么。
我当然可以为每个用户使用排序和限制查询,但这似乎效率很低。
如果有人可以指出正确的方向,我会很高兴的:)
是的,重复的: 猫鼬-查找每个用户的最后一条消息
我最终用修改了我的代码;
Record.aggregate(
[
// Matching pipeline, similar to find
{
"$match": {}
},
// Sorting pipeline
{
"$sort": {
"inserted": -1
}
},
// Grouping pipeline
{
"$group": {
"_id": "$user_id",
"message": {
"$first": "$message"
},
"inserted": {
"$first": "$inserted"
}
}
},
// Project pipeline, similar to select
{
"$project": {
"_id": 0,
"user_id": "$_id",
"message": 1,
"inserted": 1
}
}
],
function(err, messages) {
console.log(err, messages);
}
);
并更新到最新的mongodb(3.4)而不是我正在运行的旧版本(2.x)(这会产生错误,因为还不支持聚合)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.