java代码生成es索引结构

今天索引字段扩展,通过后端代码生成索引时,映射结构和定义出现不一致

  /** 商品编号 */
    @Field(type=FieldType.Keyword)
    private String productCode;

    /** 商品品牌id */
    @Field(type=FieldType.Keyword)
    private String brandId;

    /** 商品品牌名称 */
    @Field(type=FieldType.Keyword)
    private String brandName;

再代码中指定了字段类型,但是通过kibana查看映射发现不一致
所有的keyword结构都变成了如下类型

 "type" : "text",
 "fields" : {
      "keyword" : {
        "type" : "keyword",
        "ignore_above" : 256
      }
    }

最后通过手动在kibana中重置结构才得以解决
我的es版本是6.7

PUT /my_index
{
  "mappings": {
    "my_type": {
      "properties": {
        "name": {
          "type": "keyword"
        },
        "age": {
          "type": "integer"
        }
      }
    }
  }
}

7.x 版本以后删除了类型数据层,就不需要my_type这一级

有没有大佬帮忙看下为什么通过java代码生成时指定的映射关系没有生效,

本人实验场景
场景一:通过后端代码生成索引和映射关系 (失败)
场景二:通过kibana创建好索引,再通过代码生成映射关系(失败)
场景三:通过kibana创建索引并关闭动态映射,再通过代码上传数据,数据存在,但是映射关系没有生成(失败)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值