首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用Elasticsearch java驱动程序实现等价Elasticsearch巨型查询

使用Elasticsearch java驱动程序实现等价Elasticsearch巨型查询
EN

Stack Overflow用户
提问于 2014-03-17 14:01:00
回答 1查看 285关注 0票数 0

我在titan获取的Elastic搜索结果中提出了与分页相关的问题

Pagination with Elastic Search in Titan

并得出结论,它现在不支持,所以为了得到它,我决定使用ES java客户端直接搜索Titan索引。

下面是获取ES记录的泰坦方法:

代码语言:javascript
复制
Iterable<Result<Vertex>> vertices = g.indexQuery("search","v.testTitle:(mytext)")
        .addParameter(new Parameter("from", 0))
        .addParameter(new Parameter("size", 2)).vertices();    

for (Result<Vertex> result : vertices) {
    Vertex tv = result.getElement();
    System.out.println(tv.getProperty("testTitle")+ ": " + result.getScore());
}

其返回值为1记录。

但不支持addParameter(),因此不允许分页。所以我想直接从ES java客户端做同样的事情,如下所示:

代码语言:javascript
复制
Node node = nodeBuilder().node();
Client client = new TransportClient().addTransportAddress(new InetSocketTransportAddress("127.0.0.1", 9300));

        SearchResponse response = client.prepareSearch("titan")
        .setSearchType(SearchType.DFS_QUERY_THEN_FETCH)
        .setQuery(QueryBuilders.fieldQuery("testTitle", "mytext"))             // Query
        .execute()
        .actionGet();
        System.out.println(response.getHits().totalHits());
        node.close(); 

在我的情况下它打印的是零。但Titan代码中的相同查询(如上图)返回1条记录。我是否在这段ES java代码中遗漏了一些Titan特定的参数或选项?

EN

回答 1

Stack Overflow用户

发布于 2014-03-17 15:00:49

我想泰坦正在发送一个QueryStringQuery。也就是说,我建议使用MatchQuery。

代码语言:javascript
复制
QueryBuilders.matchQuery("offerTitle", "your text whatever you want")
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22447871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档