首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Elastica PHP中的Group by?

在Elastica PHP中的Group by?
EN

Stack Overflow用户
提问于 2018-04-23 22:35:11
回答 1查看 311关注 0票数 0

在Elastica中绝对没有关于group by的文档。你知道这样的聚合是否存在吗?

我已经看到可以使用原始查询来实现这一点,但是我不能将原始查询结果与我这样编写的结果组合在一起

代码语言:javascript
复制
$bool_sub = new \Elastica\Query\Bool();
$bool->addMust($bool_sub);
$query->setFilter($bool);

在任何情况下,group by,by Elasticsearch文档,根据一种标准对结果进行计数,但我想要做的是一个类似于group by的SQL,其目标是组合所有相同的行。

EN

回答 1

Stack Overflow用户

发布于 2018-04-24 16:34:37

是的,这是可能的。您必须使用addAggregation方法。

例如elasticsearch查询:

代码语言:javascript
复制
{
    "aggs" : {
        "genders" : {
            "terms" : { "field" : "gender" }
        }
    }
}

elastica中如下所示:

代码语言:javascript
复制
use Elastica\Aggregation\Terms;
use Elastica\Query;

// set up the aggregation
$termsAgg = new Terms("genders");
$termsAgg->setField("gender");

// add the aggregation to a Query object
$query = new Query();
$query->addAggregation($termsAgg);

// retrieve the results
$index = $elasticaClient->getIndex('someindex');
$buckets = $index->search($query)->getAggregation("genders");
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49983705

复制
相关文章

相似问题

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