数据库存储json的处理

在数据库中以字符串形式存储的JSON数据,在取出并转换为JSON时需特别处理。当从数据库同步到ES时,需要将JSON字符串转换为Map对象。通过在实体类中增加一个Map属性,利用JSON工具将JSON字段解析成Map,然后将Map赋值给这个属性。序列化Pojo对象为JSON时,Map会显示为标准JSON对象而非字符串。在ES存储时,需再次将字符串转换为Map,并通过工具类转化为JSON对象才能正确插入。

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

场景:存储在数据库表的某个字段是json数据,其字段类型是字符串,
再取出来该表数据转为json时该字段如何处理?

该情况场出现在数据库同步数据到es时出现

数据库user表对应的user类,其中address属性用来存放json数据。实际中如省、市、区、街道等信息存储为一个json对象
/**用户类*/
public class User implements Comparable<User>{
    private int id;
    private String username;
    private int age;
    private String address;
   //省略构造器、get、set、toString方法
//错误转换json
@Test
    void comparableTest1() {
        User user = new User(1, "张三", 18,"{'省':'宁夏','市':'银川','区':'金凤区'}");
        String address = user.getAddress();
        System.out.println(address);
        //{'省':'宁夏','市':'银川','区':'金凤区'}
        Object o = JSON.toJSON(user);
        System.out.println(o);
        //{"address":"{'省':'宁夏','市':'银川','区':'金凤区'}","id":1,"age":18,"username":"张三"}
        //注意此处的address转换后还是一个字符串,而不是json对象

    }

解决

  1. 表对应的实体类中添加一个map属性。
  2. 将存储json的属性使用json转换工具转换为mapJSON.parseOb
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值