关于复杂数据格式的数据库存储思路,先转换为Java 集合字典对象 List<Map<String,Object>> 后再转换为数据库 json字符串存储 && 以及将 String 逆转原格式的方法

一、问题:如何存储复杂数据格式为数据库字符串数据 List<Map<String,Object>> to String

解决方法:

import com.alibaba.fastjson2.JSON;


public class TestTransForm{
    
    

public void TransFormStringjson{
    
    

	List<String> complexDataList = getComplexData();
	
	List<Map<String, Object>> transFromList = new ArrayList<>();
	
	for (String testData : complexDataList ) {
    
    
	    Map<String, Object> complexDataMap = new HashMap<>(1);
	    complexDataMap.put("testData", testData);
	    transFromList.add(complexDataMap);
	}
	// 文件路径List 对象呗转换为 json 字符串
	String json = JSON.toJSONString(transFromList);
	// 输出结果
	System.err.println(json);

	}
}

二、问题 如何将 String 字符串数据逆转回 List<Map<String,Object>> 集合 List 对象

解决方法:

import com.alibaba.fastjson2.JSONArray;


public class TestTransForm{
    
    

public void TransFormListObject{
    
    

	String complexDataString = getStringComplexData();
	// 字符串数据转换为 Json 集合 List 对象
	JSONArray complexDataList = JSON.parseArray(complexDataString);
		
    for (int i = 0; i < complexDataList.size(); i++) {
    
    
    	// 再由 Json 集合 List 对象获取其中的 Map 对象
        Map<String, Object> complexDataMap = JSON.parseObject(complexDataList.get(i).toString());
		System.err.println(complexDataMap);
		System.err.println(complexDataMap.get("testData"));
	}

	}
}

三、存储的 Json 数据格式演示:

默认如下是 Json 字符串数据

[{
    
    "testData":"123456"},{
    
    "testData":"7891011121314"}]

猜你喜欢

转载自blog.csdn.net/qq_42701659/article/details/132774396