问题背景描述
java代码保存数据到mysql的同时需要保存一份到es,由于对象字段很多,建两个实体类分别写值保存到mysql、es的话会比较繁琐,简单的方法就是公用一个实体类,通过fastjson将对象转成json存储到es,在对象转json的过程中,由于实体类本身继承了父类中的字段属性,对于mysql没有影响,insert时对应字段不保存即可,但是es的话即使已经建好了表结构(索引),如果数据中有新增字段,es会自动增加字段,导致es原有的表结构(索引)遭到破坏,那么这就需要在对象转json的过程中去掉没必要的字段,保证原始es索引结构的统一
问题处理
//返回结果有值,提前准备 对象转json 需要过滤的参数 SimplePropertyPreFilter filter = new SimplePropertyPreFilter(); Set<String> excludes = filter.getExcludes(); excludes.add("createBy"); excludes.add("createTime"); excludes.add("params"); excludes.add("remark"); excludes.add("searchValue"); excludes.add("updateBy"); excludes.add("updateTime"); SerializeFilter[] filters = {filter}; ...... //保存数据到es 转json String data = JSON.toJSONString(meiqiaConversation,filters,SerializerFeature.WriteMapNullValue); ......
这样就可以去掉不必要的的字段了,下面贴两幅图比较一下
对比两幅图可以看到红框的字段已经去掉了