场景:存储在数据库表的某个字段是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对象
}
解决:
- 表对应的实体类中添加一个map属性。
- 将存储json的属性使用json转换工具转换为map
JSON.parseObject(json串, Map.class);
- 将转换后的map赋值给map属性。
- 然后序列化表对应的pojo对象为json。
- 发现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:
success: