com.alibaba.fastjson 对象转json剔除字段

简介: com.alibaba.fastjson在对象转json时剔除不需要的字段

问题背景描述

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);
......            

这样就可以去掉不必要的的字段了,下面贴两幅图比较一下

image.png

image.png

对比两幅图可以看到红框的字段已经去掉了



相关文章
|
3小时前
|
Web App开发 JSON JavaScript
SAP UI5 应用程序小技巧 - 一键将 JSON 对象导出成本地 json 文件
SAP UI5 应用程序小技巧 - 一键将 JSON 对象导出成本地 json 文件
29 0
|
3小时前
|
存储 JSON 安全
【C++ JSON库 json值的创建手段】深入探究C++中JSON对象定位与操作:从引用到回调函数
【C++ JSON库 json值的创建手段】深入探究C++中JSON对象定位与操作:从引用到回调函数
71 0
|
3小时前
|
SQL DataWorks 关系型数据库
DataWorks操作报错合集之DataWorks在同步mysql时报错Code:[Framework-02],mysql里面有个json类型字段,是什么原因导致的
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
30 0
|
3小时前
|
分布式计算 DataWorks 关系型数据库
DataWorks产品使用合集之在DataWorks中,使用JSON解析函数将MySQL表中的字段解析成多个字段将这些字段写入到ODPS(MaxCompute)中如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
28 3
|
3小时前
|
存储 JSON DataWorks
DataWorks产品使用合集之DataWorks将 MongoDB 中的数组类型写入到 DataWorks 的单个字段时,表示为字符串格式而非 JSON 格式如何解决
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
26 3
|
3小时前
|
前端开发
【专栏】在前端开发中,package.json 文件是项目的重要配置文件,其中包含了许多与项目相关的信息和设置
【4月更文挑战第29天】`package.json`的`proxy`字段用于配置开发环境中的代理服务器,解决跨域问题并模拟后端响应。它是字符串类型,值为代理服务器地址。主要应用场景包括前端跨域请求和本地调试。配置时在`package.json`顶层添加`proxy`字段,如`"proxy": "http://localhost:8080"`。该配置仅在开发环境中生效,生产环境需另寻解决方案。
|
3小时前
|
小程序 开发者
【微信小程序】微信开发者工具 app.json: [“subpackages“][0][“root“] 字段需为目录 已解决
【微信小程序】微信开发者工具 app.json: [“subpackages“][0][“root“] 字段需为目录 已解决
13 0
|
3小时前
|
JSON C语言 数据格式
C语言与lua通过json对象交互
C语言与lua通过json对象交互
20 1
|
3小时前
|
JSON 数据格式
Json字符串与QVariantList 对象相互转换
Json字符串与QVariantList 对象相互转换
11 0
|
3小时前
|
存储 JSON JavaScript
Python如何解析json对象?
Python如何解析json对象?
28 1