Mongodb获取每个文档的用户信息

mongodb getting user info for every document

本文关键字:用户 信息 文档 获取 Mongodb      更新时间:2023-09-26

我正在尝试显示一个论坛/类别。我需要得到最新的帖子。问题是,我还需要每个帖子的用户数据以及最新的回复。

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调用就可以显示它。