我正在尝试显示一个论坛/类别。我需要得到最新的帖子。问题是,我还需要每个帖子的用户数据以及最新的回复。
db.post.find({
"inForum": forumID,
},
{
'sort': [['date', -1]]
},
function(err, cursor) {
cursor.count(function(err, count) {
cursor.skip(skip).limit(20).toArray(function(err, posts) {
var complete = _.after(nodes.length, function () {
res.send(posts)
});
// for every post get its author info and the latest post info
posts.forEach(function (post) {
var users = _.pluck(posts, 'user');
user.load(users, function (profiles) {
_.each(posts,
function(post, k) {
if (profiles[post.user]) post.fieldAvatar = profiles[post.user].fieldAvatar;
});
if (post.latestReply) {
post.load(post.latestReply.id, function (latestReply) {
if (latestReply) post.latestReply = latestReply
complete()
})
}
else {
complete()
}
})
})
});
})
})
这就是我正在做的,对我来说它看起来真的很慢/真的很不优雅。我这样做是正确的吗?有什么建议可以加快速度吗?
谢谢。
你最好在这里嵌入一些文章作者的信息(用户名&电子邮件或头像)到那些帖子中,这样你就不会对数据库进行多次查询,一次就足够了(当然你有一些重复的数据,但性能是最佳的)。
如果你不想/不能这样做,你也可以修改你的第二个查询来查找[array_of_ids_of_the_posts]中的所有作者。这将减少您的[number_of_posts]查询到只有一个。
您可以使用一些缓存。例如,你可以在循环期间将用户保存在字典中,这样你只需要在第一次从mongodb中获取它。
也许你可以创建某种线程模型,在其中保存包含帖子的基本信息,这样你只需要浏览线程。
您可以保存函数的结果,并在添加新帖子时删除它。所以我不会每次打电话都看所有的帖子。
您不应该使用像sql数据库这样的文档存储。也许最好在帖子创建/编辑时直接生成论坛页面,并将整个数据保存在文档中,这样您只需要对mongo进行一次read调用就可以显示它。