map集合与json、实体类的相互转换

这里创建一个User对象 :User user = new User();
用到了fastjson,引入了fastjson的依赖

<dependency>
   <groupId>com.alibaba</groupId>
    <artifactId>fastjson</artifactId>
    <version>1.2.54</version>
</dependency>
Map、实体类转Json
// 将 Map 转换为 Json
String s = JSON.toJSONString(user01)
System.out.println(s);
// 将 User 转换为 Json
String s2 = JSON.toJSONString(User)
System.out.println(s2);
Json转Map、对象
// 将 Json 转换为 Map
Map map = JSON.parseObject(s, Map.class);
System.out.println(map);
// 将 Json 转换为 实体类
User user = JSON.parseObject(s2, User.class);
System.out.println(user);
Map与对象

第一种方式:至于实体类和Map之间的转换,先转成json就行了
第二种方式:

// Map转对象
public static Map<String, Object> objectToMap(Object obj) throws IllegalAccessException {
        Map<String, Object> map = new HashMap<>();
        Class<?> clazz = obj.getClass();
        for (Field field : clazz.getDeclaredFields()) {
            field.setAccessible(true);
            String fieldName = field.getName();
            Object value = field.get(obj);
            map.put(fieldName, value);
        }
        return map;
    }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实体类中的map集合类型的数据存储到数据库中,需要先将map集合转换json格式的字符串,然后将字符串存储到数据库中的对应字段中。具体实现过程可以参考以下代码: 1. 将map集合转换json格式的字符串 ``` import com.alibaba.fastjson.JSONObject; public class MapToJsonUtil { public static String map2Json(Map<String, Object> map) { JSONObject jsonObject = new JSONObject(); for (Map.Entry<String, Object> entry : map.entrySet()) { jsonObject.put(entry.getKey(), entry.getValue()); } return jsonObject.toJSONString(); } } ``` 2. 将json格式的字符串存储到数据库中 假设需要将map集合存储到名为"table_name"的表中的字段"map_data"中,可以使用以下代码实现: ``` import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; public class MapToDBUtil { public static void saveMapToDB(Map<String, Object> map) { String url = "jdbc:mysql://localhost:3306/db_name"; String username = "root"; String password = "root"; Connection conn = null; PreparedStatement ps = null; try { Class.forName("com.mysql.jdbc.Driver"); conn = DriverManager.getConnection(url, username, password); String sql = "insert into table_name(map_data) values(?)"; ps = conn.prepareStatement(sql); ps.setString(1, MapToJsonUtil.map2Json(map)); ps.executeUpdate(); } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } finally { try { if (ps != null) { ps.close(); } if (conn != null) { conn.close(); } } catch (SQLException e) { e.printStackTrace(); } } } } ``` 以上代码是一个简单的示例,实际应用中需要根据具体情况进行适当修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值