业务场景:Mysql使用Key/Value方式存储动态扩展字段,json对象转map,map转list
如:某表添加extend字段,内容存储为{“姓名”:“233”,“爱好”:“足球”},
将其转化为[{“fieldName”:“姓名”,“fieldValue”:“233”},{“fieldName”:“爱好”,“fieldValue”:“足球”}]。核心代码如下:
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
// 将对象属性转化为map集合
Map<String, Object> map = JSON.parseObject(JSONObject.toJSONString(json对象), HashMap.class);
// map转为List<ExtendVO>
List<ExtendVO> extendMapList = map.entrySet().stream().map(
e -> new ExtendVO(e.getKey(),e.getValue()))
.collect(Collectors.toList()
);
附ExtendVO.java
import lombok.AllArgsConstructor;
import lombok.Getter;
import lombok.Setter;
import java.io.Serializable;
/***
* @ClassName: ExtendVO
* @Desc: 扩展字段返回实体类
* @author: wu_yang
* @CreateTime: 2021/1/8 10:44
*/
@Getter
@Setter
@AllArgsConstructor
public class ExtendVO implements Serializable {
private static final long serialVersionUID = 1L;
/**
* 字段名
*/
private String fieldName;
/**
* 字段内容
*/
private Object fieldValue;
}