繁体   English   中英

使用MongoDB和ExpressJS进行Elasticsearch分页

[英]Elasticsearch pagination with MongoDB and ExpressJS

我试图在网上搜索解决方案,但老实说,我仍然没有找到任何可以帮助我实现这一目标的方法。

这是我第一次使用ElasticSearch,而Node和MongoDB也是我的新手。

因此,我遵循了一种教程并从NPM实施了Mongooastic,以使ElasticSearch与Node一起工作。

即使在总共12个被索引的用户上,它似乎也可以正常工作,如果我在搜索列表视图中键入搜索“ user”,我可以找到12条记录,则每条显示10条记录,而第一个记录缺少值。 ..

但是对我来说主要的问题是分页...或某种...在其上实现无限滚动也将很好,但是我真的不知道如何处理它。

因此,目前处理它的控制器如下:

exports.searchUsers = function(req, res) {
    User.search({
      query_string: {
        query: req.query.q
      }
    },
    { hydrate: true },
    function(err, results) {
      if (err) res.send(err);
      res.render('search-results', {
        results: results,
        users: results.hits.hits
      });
    });
};

我真的不知道在哪里放置size以及from这里开始。在理解了这一点之后,我还想知道如何实现(如果可能)一种无限滚动...以及如何处理链接。分页...即: prev, 1, 2, 3, 4, ..., next

该视图有一个简单的输入文本供搜索,按提交后,它会打开一个包含hits列表的新页面,因此应该没有什么复杂的...

希望您能提供帮助。 谢谢

默认情况下,elasticsearch返回前10个结果:如果需要更多则必须设置size参数。

另外,为了增加大小参数中,您需要像这样编写查询:

User.search({
    query: {
      query_string: {
        query: req.query.q
      }
    },
    size: 30,
    from: 30
  },
  {hydrate: true},
  function (err, results) {
    if (err) res.send(err);
    res.render('search-results', {
      results: results,
      users: results.hits.hits
    });
  });

(参见这里: https : //github.com/taterbase/mongoosastic/issues/123

这将使您的用户n°30达到用户n°60(此处有更多信息: http : //www.elasticsearch.org/guide/zh-CN/elasticsearch/reference/current/search-request-from-size.html )。 您将必须使用前端才能 大小和参数中获取所需的值。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM