elasticsearch条件查询语句与聚合查询语句模板

https://blog.csdn.net/lpp_dd/article/details/73136059

 

字段解释:

 

条件查询:

_source:表示需要展示的字段

聚合查询

field: 表示聚合的字段

size 显示条数

order 排序方法

 

1、条件查询语句

 

 
  1. {

  2. "_source": [

  3. "UUID",

  4. "workOrderData.appNo"

  5. ],

  6. "query": {

  7. "bool": {

  8. "must": [

  9. {

  10. "terms": {

  11. "workOrderData.appNo": [

  12. "2017060487300285"

  13. ]

  14. }

  15. }

  16. ],

  17. "must_not": [],

  18. "should": []

  19. }

  20. },

  21. "size": 100

  22. }

         

 

2、聚合查询语句

例子1

 

 
  1. {

  2. "query": {

  3. "bool": {

  4. "must": [

  5. {

  6. "terms": {

  7. "workOrderData.center": [

  8. "7110101",

  9. "7110102"

  10. ]

  11. }

  12. }

  13. ],

  14. "must_not": [],

  15. "should": []

  16. }

  17. },

  18. "size": 0,

  19. "aggs": {

  20. "aggs_block": {

  21. "terms": {

  22. "field": "workOrderData.busiType"

  23. }

  24. }

  25. }

  26. }

例子2

 

 
  1. {

  2. "query": {

  3. "bool": {

  4. "must": [

  5. {

  6. "range": {

  7. "relateData.callTime": {

  8. "gte": "2016-07-26 00:00:00"

  9. }

  10. }

  11. },

  12. {

  13. "range": {

  14. "relateData.callTime": {

  15. "lte": "2017-08-02 23:59:59"

  16. }

  17. }

  18. }

  19. ]

  20. }

  21. },

  22. "size": 0,

  23. "aggs": {

  24. "1": {

  25. "terms": {

  26. "field": "analysisData.competitorList",

  27. "size": 10,

  28. "order": {

  29. "_count": "desc"

  30. }

  31. }

  32. }

  33. }

  34. }

 

 

3、should字段和must字段一起使用

例子1(should和must同级使用)

 

 
  1. {

  2. "_source": [

  3. "relateData.orderNum",

  4. "relateDate.businessType",

  5. "relateData.agentGroupName",

  6. "relateData.agentDepartmentName",

  7. "relateData.acceptTime",

  8. "analysisData.is_rule_complain"

  9. ],

  10. "query": {

  11. "bool": {

  12. "must": [

  13. {

  14. "range": {

  15. "relateData.callTime": {

  16. "gte": "2017-02-22 00:00:00",

  17. "lte": "2017-08-16 23:59:59"

  18. }

  19. }

  20. }

  21. ],

  22. "should": [

  23. {

  24. "term": {

  25. "transData.emotionList.emtionType": {

  26. "value": "2"

  27. }

  28. }

  29. },

  30. {

  31. "term": {

  32. "analysisData.is_rule_complain": {

  33. "value": "是"

  34. }

  35. }

  36. }

  37. ]

  38. }

  39. },

  40. "sort": {

  41. "relateData.acceptTime": {

  42. "order": "desc"

  43. }

  44. },

  45. "from": 0,

  46. "size": 10

  47. }


在这里should里面的条件满足一条就可以。相当于or

 

但是当should与must一起使用时候就失去了should的意义 因为只要满足must的条件就可以

 

例子2(should为must的上一级)

当我们有and 和 or 并列的查询要求时,(a==0 && b== 0 && (c==0 || d== 0))

我们可以使用如下的elasticsearch查询语句

在should里面包含bool

 

 

 
  1. {

  2. "_source": [

  3. "relateData.orderNum",

  4. "relateDate.businessType",

  5. "relateData.agentGroupName",

  6. "relateData.agentDepartmentName",

  7. "relateData.acceptTime",

  8. "analysisData.is_rule_complain"

  9. ],

  10. "query": {

  11. "bool": {

  12. "should": [

  13. {

  14. "bool": {

  15. "must": [

  16. {

  17. "range": {

  18. "relateData.callTime": {

  19. "gte": "2017-02-22 00:00:00",

  20. "lte": "2017-08-16 23:59:59"

  21. }

  22. }

  23. },

  24. {

  25. "term": {

  26. "transData.emotionList.emtionType": {

  27. "value": "2"

  28. }

  29. }

  30. }

  31. ]

  32. }

  33. },

  34. {

  35. "bool": {

  36. "must": [

  37. {

  38. "range": {

  39. "relateData.callTime": {

  40. "gte": "2017-02-22 00:00:00",

  41. "lte": "2017-08-16 23:59:59"

  42. }

  43. }

  44. },

  45. {

  46. "term": {

  47. "analysisData.is_rule_complain": {

  48. "value": "是"

  49. }

  50. }

  51. }

  52. ]

  53. }

  54. }

  55. ]

  56. }

  57. }

  58. }

 

4、aggs嵌套聚合语句

 

 
  1. {

  2. "query": {

  3. "bool": {

  4. "must": [

  5. {

  6. "range": {

  7. "relateData.callTime": {

  8. "gte": "2017-08-30 00:00:00"

  9. }

  10. }

  11. },

  12. {

  13. "range": {

  14. "relateData.callTime": {

  15. "lte": "2017-09-06 23:59:59"

  16. }

  17. }

  18. }

  19. ]

  20. }

  21. },

  22. "size": 0,

  23. "aggs": {

  24. "1": {

  25. "terms": {

  26. "field": "relateData.businessType",

  27. "size": 15,

  28. "order": {

  29. "_count": "desc"

  30. }

  31. },

  32. "aggs": {

  33. "2": {

  34. "terms": {

  35. "field": "qualityData.ATTENTION_WORD.keyWord.keyword",

  36. "order": {

  37. "_count": "desc"

  38. }

  39. },

  40. "aggs": {

  41. "3": {

  42. "terms": {

  43. "field": "relateData.customerPhoneNo",

  44. "size": 2147483647,

  45. "min_doc_count": 2

  46. }

  47. }

  48. }

  49. }

  50. }

  51. }

  52. }

  53. }

查询部分结果展示:

 

 

 
  1. "hits": {

  2. "total": 190,

  3. "max_score": 0,

  4. "hits": []

  5. },

  6. "aggregations": {

  7. "1": {

  8. "doc_count_error_upper_bound": 0,

  9. "sum_other_doc_count": 0,

  10. "buckets": [

  11. {

  12. "2": {

  13. "doc_count_error_upper_bound": 0,

  14. "sum_other_doc_count": 0,

  15. "buckets": [

  16. {

  17. "3": {

  18. "doc_count_error_upper_bound": 0,

  19. "sum_other_doc_count": 0,

  20. "buckets": [

  21. {

  22. "key": "13554186343",

  23. "doc_count": 2

  24. },

  25. {

  26. "key": "13554186390",

  27. "doc_count": 2

  28. },

  29. {

  30. "key": "13554186399",

  31. "doc_count": 2

  32. }

  33. ]

  34. },

  35. "key": "减肥",

  36. "doc_count": 8

  37. },

  38. {

  39. "3": {

  40. "doc_count_error_upper_bound": 0,

  41. "sum_other_doc_count": 0,

  42. "buckets": [

  43. {

  44. "key": "13554186356",

  45. "doc_count": 2

  46. },

  47. {

  48. "key": "13554186389",

  49. "doc_count": 2

  50. }

  51. ]

  52. },

  53. "key": "是个",

  54. "doc_count": 7

  55. },

  56. {

  57. "3": {

  58. "doc_count_error_upper_bound": 0,

  59. "sum_other_doc_count": 0,

  60. "buckets": [

  61. {

  62. "key": "13554186389",

  63. "doc_count": 2

  64. }

  65. ]

  66. },

  67. "key": "绿瘦",

  68. "doc_count": 4

  69. }

  70. ]

  71. },

  72. "key": "故障",

  73. "doc_count": 187

  74. }

查询的结果为:首先聚合业务类型,然后聚合业务关注词,最后聚合电话号,聚合结果的意义为在指定业务类型下的指定的业务关注词下的重复来电电话与个数。

5、interval关键字的使用

 

 

 
  1. {

  2. "query": {

  3. "bool": {

  4. "must": [

  5. {

  6. "range": {

  7. "relateData.callTime": {

  8. "gte": "2017-08-30 00:00:00"

  9. }

  10. }

  11. },

  12. {

  13. "range": {

  14. "relateData.callTime": {

  15. "lte": "2017-09-06 23:59:59"

  16. }

  17. }

  18. }

  19. ]

  20. }

  21. },

  22. "size": 0,

  23. "aggs": {

  24. "1": {

  25. "terms": {

  26. "field": "qualityData.ATTENTION_WORD.keyWord.keyword",

  27. "size": 10,

  28. "order": {

  29. "_count": "desc"

  30. }

  31. },

  32. "aggs": {

  33. "2": {

  34. "date_histogram": {

  35. "field": "relateData.callTime",

  36. "interval": "1d",

  37. "extended_bounds": {

  38. "min": "2017-08-30 00:00:00",

  39. "max": "2017-09-06 23:59:59"

  40. }

  41. }

  42. }

  43. }

  44. }

  45. }

  46. }

结果展示:

 

 

 
  1. "aggregations": {

  2. "1": {

  3. "doc_count_error_upper_bound": 0,

  4. "sum_other_doc_count": 0,

  5. "buckets": [

  6. {

  7. "2": {

  8. "buckets": [

  9. {

  10. "key_as_string": "2017-08-30 00:00:00",

  11. "key": 1504051200000,

  12. "doc_count": 0

  13. },

  14. {

  15. "key_as_string": "2017-08-31 00:00:00",

  16. "key": 1504137600000,

  17. "doc_count": 0

  18. },

  19. {

  20. "key_as_string": "2017-09-01 00:00:00",

  21. "key": 1504224000000,

  22. "doc_count": 0

  23. },

  24. {

  25. "key_as_string": "2017-09-02 00:00:00",

  26. "key": 1504310400000,

  27. "doc_count": 0

  28. },

  29. {

  30. "key_as_string": "2017-09-03 00:00:00",

  31. "key": 1504396800000,

  32. "doc_count": 0

  33. },

  34. {

  35. "key_as_string": "2017-09-04 00:00:00",

  36. "key": 1504483200000,

  37. "doc_count": 0

  38. },

  39. {

  40. "key_as_string": "2017-09-05 00:00:00",

  41. "key": 1504569600000,

  42. "doc_count": 0

  43. },

  44. {

  45. "key_as_string": "2017-09-06 00:00:00",

  46. "key": 1504656000000,

  47. "doc_count": 8

  48. }

  49. ]

  50. },

  51. "key": "减肥",

  52. "doc_count": 8

  53. }

interval关键字使得在聚合callTime字段的时候是按照1天的间隔进行聚合,这对于数据统计过长时间范围内能够更加智能的查询,不会导致横坐标过于密。

 

extended_bounds字段表示强制的将数据显示在指定的时间范围,防止查询的结果超出预期范围。

6、正则表达式

 

 
  1. "query": {

  2. "regexp":{

  3. "name.first": "s.*y"

  4. }

  5. }

### 回答1: Elasticsearch 查询语句可以使用 Query DSL 进行构建。以下是一些常见的查询语句示例: 1. 匹配查询:用于匹配一个特定字段中的值。 ``` GET /_search { "query": { "match": { "title": "elasticsearch" } } } ``` 2. 短语查询:用于匹配一个特定字段中的短语。 ``` GET /_search { "query": { "match_phrase": { "title": "elasticsearch tutorial" } } } ``` 3. 范围查询:用于匹配一个特定字段中的数值范围。 ``` GET /_search { "query": { "range": { "age": { "gte": 18, "lte": 30 } } } } ``` 4. 布尔查询:用于组合多个查询条件。 ``` GET /_search { "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" } }, { "match": { "description": "tutorial" } } ] } } } ``` 5. 聚合查询:用于对结果进行聚合计算。 ``` GET /_search { "aggs": { "avg_age": { "avg": { "field": "age" } } } } ``` 以上仅是一些常见的查询语句示例,Elasticsearch 还支持许多其他类型的查询。请参阅官方文档以了解更多信息。 ### 回答2: Elasticsearch 是一个开源的分布式搜索和分析引擎,它提供了强大的查询功能来检索和分析大量的数据。 Elasticsearch 查询语句可以使用 JSON 格式来构建,主要分为两种类型:查询查询语句和过滤查询语句。 查询查询语句用于根据特定的条件从索引中检索文档。常见的查询类型包括匹配查询、多字段查询、范围查询和布尔查询等。匹配查询用于在指定字段中搜索指定的词语,多字段查询可以在多个字段中搜索相同的词语,范围查询支持按照范围来搜索结果,而布尔查询则可以通过逻辑运算符组合多个查询条件。 过滤查询语句用于根据特定的条件过滤文档。与查询查询语句不同的是,过滤查询不会计算相关度分数,只关心是否匹配。常见的过滤查询类型有 term 过滤、范围过滤和 bool 过滤等。term 过滤用于精确匹配一个词语,范围过滤用于按照指定范围过滤结果,bool 过滤则可以通过逻辑运算符组合多个过滤条件。 除了查询和过滤,Elasticsearch 还支持一些聚合函数(aggregations),用于对搜索结果进行统计和分析。聚合查询可以对结果集进行分组、排序、计算总和、平均值等操作,从而提供更丰富的数据分析功能。 总之,Elasticsearch 查询语句是非常灵活和强大的,可以根据不同的需求组合不同的查询和过滤条件,实现高效的数据检索和分析。 ### 回答3: Elasticsearch是一个开源的分布式搜索和分析引擎,提供了强大的查询功能。查询语句是用户用来向Elasticsearch发送请求并获取结果的指令。 Elasticsearch查询语句可以分为两种,一种是基于URI的查询语句,另一种是基于请求体的查询语句。 基于URI的查询语句通常用于简单的查询请求,语法类似于URL。例如,要查询名为"products"的索引下的所有文档,可以使用以下查询语句: GET /products/_search 基于请求体的查询语句更为灵活,可以实现更复杂的查询功能。请求体是一个JSON对象,包含了查询的参数和条件。以下是一个常见的基于请求体的查询语句示例: POST /products/_search { "query": { "match": { "name": "手机" } } } 上述查询语句使用了"match"查询,指定了要查询的字段为"name",查询的关键词为"手机"。这将返回所有名为"手机"的文档。 此外,Elasticsearch还提供了许多其他类型的查询语句,包括布尔查询、范围查询、模糊查询等。用户可以根据需要选择合适的查询语句以实现精确的搜索结果。 总之,Elasticsearch查询语句是通过URI或请求体来发送查询请求的指令,使用不同类型的查询语句可以实现不同的搜索功能。用户可以根据自己的需求选择合适的查询语句,并通过分析返回的结果来满足他们的搜索和分析需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值