我在Elasticsearch中有问题。在控制台Kibana中,我正在执行以下代码,
GET bounce_gmd/_search
{
"query": { "match_phrase": { "date_added": "2017-02-08" } },
"size": 0,
"aggs": {
"date_added": {
"terms": {
"field": "bounce_type.keyword"
}
}
}
}
我有这个结果。
{
"took": 1,
"timed_out": false,
"_shards": {
"total": 5,
"successful": 5,
"failed": 0
},
"hits": {
"total": 129812,
"max_score": 0,
"hits": []
},
........................... and many more lines.
但是,当我从laravel项目运行时,没有得到这个结果。
我的php代码看起来像这样,
$params['index'] = $index_name;
$params['type'] = $index_name;
$params['body'] = $json;
$params['body']['query']['match_phrase']['date_added'] = $now_time;
$params['body']['size']=0;
$params['body']['aggs']['bounce_type']['terms']['field']='bounce_type.keyword';
$response = $client->search($params);
这里$ index_name ='bounce_gmd'和$ now_time =“2017-02-08”。
但是答案是
我将代码更改为
$json='{
"query": { "match_phrase": { "date_added": "2017-02-08" } },
"size": 0,
"aggs": {
"date_added": {
"terms": {
"field": "bounce_type.keyword"
}
}
}
}
';
$params = [
'index' => $index_name,
'type' => $index_name,
'body' => $json
];
但是答案仍然是一样的。我不明白是什么问题。请帮我。
最佳答案
为什么在0上指定尺寸?它应该有一些值(value)。而且您的聚合还可以包含可能的大小(每个aggs应该采用最大可能的选项)。工作查询的一些示例:
{
"from" : 0,
"size" : 10,
"query" : {
"match" : {
"body":
{
"query":"press key handler ",
"operator":"or",
"analyzer":"english"
}
}
},
"aggs" : {
"category_aggs" : { "terms" : { "field": "category", "size":25}},
"year_aggs" : { "terms" : { "field": "year", "size":30}},
"post_type_aggs" : { "terms" : { "field": "post_type", "size":2}}
}
}