Elasticsearch 聚合搜索报错:mapping 没有keyword 解决

在Elasticsearch中,尝试对text类型的字段进行聚合搜索时遇到错误,提示需要使用keyword字段。错误源于text字段不支持聚合操作。解决方案是将相关字段的mapping更改为keyword类型,同时在查询时指定keyword。修改mapping并应用后,聚合搜索成功执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

错误案例

1、创建商品索引product1

PUT /product1
{
  "mappings": {
    "properties": {
      "brand_name": {
        "type": "text"
      },
      "product_name": {
        "type": "text"
      },
      "color": {
        "type": "text"
      },
      "attr": {
        "type": "text"
      },
      "price": {
        "type": "long"
      }
    }
  }
}

2、增加商品数据如下:


POST /product1/_bulk
{"index":{"_index":"product1","_id":"1"}}
{"brand_name":"李宁","product_name":"夏日清凉短袖","color":"白色","price":99,"attr":"短袖"}
{"index":{"_index":"product1","_id":"2"}}
{"brand_name":"李宁","product_name":"夏日清凉短袖","color":"黑色","price":99,"attr":"短袖"}
{"index":{"_index":"product1","_id":"3"}}
{"brand_name":"李宁","product_name":"夏日清凉长袖","color":"白色","price":99,"attr":"长袖"}
{"index":{"_index":"product1","_id":"4"}}
{"brand_name&#
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值