ElasticSearch查询实例等记录

查询实例:

1.type:xxx,value:xxx

复制代码
{
  "size": 0,
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "内容": "资产/负债"
          }
        }
      ]
    }
  },
  "aggs": {
    "3": {
      "terms": {
        "field": "所属年份",
        "size": 20
      },
      "aggs": {
        "4": {
          "terms": {
            "field": "数值"
          }
        }
      }
    }
  }
}

2.多条件查询 must变成数组,里面写成对象的形式

3.查询最新一年:range:{xxx,format:xxx} 最新几个月

elasticsearch时间范围查询中的format参数用于指定日期格式。当执行时间范围查询时,elasticsearch需要知道如何解析和比较日期字段的值。

format参数可以接受多种日期格式,例如:"yyyy-MM-dd","yyyy/MM/dd","dd.MM.yyyy"等。通过指定正确的日期格式,elasticsearch可以正确地解析日期字段的值,并将其与查询中指定的时间范围进行比较。

如果没有明确指定format参数,elasticsearch会尝试使用默认的日期格式进行解析。然而,如果日期字段的值不符合默认的格式,那么查询可能会失败或者返回不准确的结果。

因此,在执行时间范围查询时,确保正确指定format参数以匹配日期字段的实际格式,这样可以确保查询的准确性和一致性。

没有配置format的时候,查询出来的数据少了最新一年最新一个月份的

3-1.需求:取最新一年,最新10个月的数据
复制代码
      "date_histogram": {
        "field": "所属年份",
        "interval": "1M",
        "time_zone": "Asia/Shanghai"
      },
// 暂未理解,写成"terms": {"field": "所属年份","size": 99}, 也是正确结果好像

{
  "size": 0,
    "query": {
    "bool": {
      "must": [
        {
          "term": {
            "内容": "客服答疑数"
          }
        },
        {
          "range": {
            "_time": {
              "gte": "now/y",
              "lt": "now/d",
              "format": "yyyy-MM-dd HH:mm:ss",
              "time_zone": "+08:00"
            }
          }
        }
      ]
    }
  },
  "aggs": {
    "3": {
      "date_histogram": {
        "field": "所属年份",
          "interval": "1M",
          "time_zone": "Asia/Shanghai"
      },
      "aggs": {
        "4": {
          "sum": {
            "field": "数值"
          }
        }
      }
    }
  }
}
3-2.查询最新一年最新一个月 不同类型内容求和

可以先取出最新一年中最新几个月的,在通过js取数组中第一个就是最新的一个月的数据

复制代码
{
  "size": 0,
  "query": {
    "bool": {
      "must": [
        {
          "term": {
            "资金性质": "活期"
          }
        },
        {
          "range": {
            "_time": {
              "gte": "now/M-10M",
              "lt": "now/d+1d",
              "format": "yyyy-MM-dd HH:mm:ss",
              "time_zone": "+08:00"
            }
          }
        }
      ]
    }
  },
  "aggs": {
    "1": {
     // es提供的时间处理函数 
      "date_histogram": {
        "field": "所属年份",// 需要聚合分组的字段名称, 类型需要为date, 格式没有要求
        "interval": "1M", // 按什么时间段聚合, 5m就是5分钟, 可用的interval在上面给出
        "time_zone": "Asia/Shanghai" // 设置时区, "time_zone":"+08:00", 这样就相当于东八区的时间
      },
      "aggs": {
        "2": {
          "sum": {
            "field": "金额(万元)"
          }
        }
      }
    }
  }
}

最后再取数组中第0位即可

3-2.查询最近一周

4.模糊查询 分词wildcard

其中?代表任意一个字符*代表任意的一个或多个字符 ??

复制代码
{
  "size": 0,
  "query": {
    "bool": {
      "must": [
        {
          "wildcard": {
            "内容": "*本年预算支出*"  //其中?代表任意一个字符,*代表任意的一个或多个字符
          }
        },
        {
          "range": {
            "_time": {
              "gte": "now/y",
              "lt": "now/d+1d",
              "format": "yyyy-MM-dd HH:mm:ss",
              "time_zone": "+08:00"
            }
          }
        }
      ]
    }
  },
  "aggs": {
    "1": {
      "sum": {
        "field": "本年数(元)"
      }
    }
  }
}

5.查询部分数据

{

"size": 10,

"query": {

"bool": {

"must": {

"match_all": {}

},

"filter": {

"bool": {

"must": [

{

"match_all": {}

}

],

"must_not": \[\]

}

}

}

},

"_source": [

"媒体名称",

"采访事由",

"联系单位",

"是否同意采访"

],

"aggs": {}

}

相关推荐
XIAOHEZIcode18 小时前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
用户0328472220701 天前
如何搭建本地yum源(上)
运维
大树884 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠4 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质4 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
Inhand陈工4 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智4 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_4 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
施努卡机器视觉4 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
AC赳赳老秦5 天前
用 OpenClaw 搭建服务器故障应急响应系统,自动处理 80% 常见运维故障
android·运维·服务器·python·rxjava·deepseek·openclaw