场景:存储在数据库表的某个字段是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.parseObject(json串, Map.class);
  3. 将转换后的map赋值给map属性。
  4. 然后序列化表对应的pojo对象为json。
  5. 发现map属性被成功转为了一个标准的json对象而不是带着""的字符串
    在往es里存储时候需要将该字符串转为map,然后使用工具类转为json对象才可以插入成功
数据库user表对应的user类,其中address属性用来存放json数据。实际中如省、市、区、街道等信息存储为一个json对象
/**用户类*/
public class User implements Comparable<User>{
    private int id;
    private String username;
    private int age;
    @JSONField(serialize = false)//该属性可以在转为json时跳过该字段
    private String address;
   private Map map;//用于存储address中的json数据转换为map后的数据
   //省略构造器、get、set、toString方法
@Test
    void comparableTest1() {
        User user = new User(1, "张三", 18,"{'省':'宁夏','市':'银川','区':'金凤区'}");
        String address = user.getAddress();
        System.out.println(address);
        //{'省':'宁夏','市':'银川','区':'金凤区'}
        Map map = JSON.parseObject(address, Map.class);
        System.out.println(map);
        user.setMap(map);
        //{省=宁夏, 市=银川, 区=金凤区}
        Object o = JSON.toJSON(user);
        System.out.println(o);
        //{"address":"{'省':'宁夏','市':'银川','区':'金凤区'}","id":1,"map":{"省":"宁夏","市":"银川","区":"金凤区"},"age":18,"username":"张三"}
    //添加@JSONField(serialize = false)注解后的json值
    //{"id":1,"map":{"省":"宁夏","市":"银川","区":"金凤区"},"age":18,"username":"张三"}
    //注意此处的map的数据就是成功转换后的json数据
    }

此处用JSON格式化工具展示两者不同

error:

ios json存数据库 json储存数据库_json

success:

ios json存数据库 json储存数据库_User_02