码迷,mamicode.com
首页 > 其他好文 > 详细

[Elasticsearch] 常用查询和操作总结

时间:2015-08-28 00:49:44      阅读:547      评论:0      收藏:0      [点我收藏+]

标签:elasticsearch   操作   索引   查询   搜索   

1. 取得某个索引中某个字段中的所有出现过的值

这种操作类似于使用SQL的SELECT UNIQUE语句。当需要获取某个字段上的所有可用值时,可以使用terms聚合查询完成:

GET /index_streets/_search?search_type=count
{
 "aggs": {
   "uniq_streets": {
     "terms": {
       "field": "name.raw",
       "size": 0
     }
   }
 } 
} 

因为目标是得到name字段上的所有出现过的值,因此search_type被设置为了count,这样在返回的响应中不会出现冗长的hits部分。另外,查询的目标字段的索引类型需要设置为not_analyzed。所以上面的field指定的是name.raw。

得到的响应如下所示:

{
   "took": 23,
   "timed_out": false,
   "_shards": {
      "total": 5,
      "successful": 5,
      "failed": 0
   },
   "hits": {
      "total": 7445,
      "max_score": 0,
      "hits": []
   },
   "aggregations": {
      "uniq_blocks": {
         "doc_count_error_upper_bound": 0,
         "sum_other_doc_count": 0,
         "buckets": [
            {
               "key": "江苏路",
               "doc_count": 29
            },
            {
               "key": "南京东路",
               "doc_count": 28
            },
         ...
      ...
   ...

本文将会不断更新。

版权声明:本文为博主原创文章,未经博主允许不得转载。

[Elasticsearch] 常用查询和操作总结

标签:elasticsearch   操作   索引   查询   搜索   

原文地址:http://blog.csdn.net/dm_vincent/article/details/48039475

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!