JSONField解决序列化与反序列化字段匹配问题

本文介绍了在处理第三方JSON数据时遇到的字段映射问题,包括反序列化实体时的匹配问题和序列化时不需要显示的字段处理。通过使用JSONField注解,可以在getter/setter或字段上进行配置,解决字段名称不匹配及字段不序列化的需求。同时还提到了使用format、serialize/deserialize和ordinal属性来进一步定制序列化行为。
摘要由CSDN通过智能技术生成
需求:调用第三方数据,数据格式为Json,并提供一个接口将获取的第三方数据给本公司其他部门调用。

处理流程:第三方Json--反序列化实体--保存到本地数据库--查询数据--序列化Json数据供本公司调用。简化为:json--实体--json。

遇到问题:

1,把数据存到本地后,怎么取数据,各层级之间怎么关联?

2,json--实体,反序列化,有的实体中数据为null,未能解析到json数据?

3,实体--json,序列化,有的实体中的字段(比如:解决问题1时,增加的字段id,recordId)不需要序列化Json数据,即不需要展示给用户,如何不序列化?

解决方法:

1,创建表结构时,增加两个字段,id,recordId,id为每一层的主键,recordId为关联字段,用外层的id,对应里层recordId,让每一层建立关联关系,实现查询。

2,原因:Json数据中key与实体中定义字段不匹配。

看一下:json数据中key用下划线分割,而实体中定义变量时,形式为驼峰格式,这时可以正常解析,实体中对应属性有值。

而Json中标红的数据,用点分割(注意实体中不能直接定义用点分割的变量。),无法反序列化到实体。

解决方案一:注解加到变量上,用@JSONField(name = " "),对应json中key。

解决方案二:注解加到方法上,把该注解@JSONField(name = " "),加到set/get方法上,关键是加到set还是get方法上?结论是加到set方法上,可以理解为给实

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值