数据库中存进去的是json类型的数据,也对应java实体类的集合,但是取出来的时候为什么会变成linkedhashmap的集合了,导致要遍历集合的时候就报类型转化异常,比如实体类中的这个字段@TableField(typeHandler = JacksonTypeHandler.class) private List<CalendarItemVO> calendarData;我取的时候获取这个字段返回的是List<CalendarItemVO>,但我要进行遍历操作的时候就会报出异常,怎么解决这个问
时间: 2024-02-23 20:00:27 浏览: 84
这个问题的原因是因为 MyBatis 返回的查询结果是一个 Map 类型的对象,其中的键是数据库表中的字段名,而值是对应字段的值。当你查询的字段是一个 JSON 类型的字段时,查询结果就会是一个 LinkedHashMap 类型的对象。这就导致了当你取出这个字段时,得到的是一个 LinkedHashMap 对象,而不是你需要的 List<CalendarItemVO> 对象。
为了解决这个问题,你可以使用 MyBatis 提供的 TypeHandler 或者自定义 TypeHandler 来将 JSON 转换为 Java 对象。在你的示例中,你使用了 JacksonTypeHandler 来将 JSON 转换为 List<CalendarItemVO> 对象,但是在查询结果中得到的是 LinkedHashMap 对象,所以需要进行进一步的转换。
你可以在你的 TypeHandler 中实现将 LinkedHashMap 转换为 List<CalendarItemVO> 对象的逻辑。例如:
```java
public class JacksonTypeHandler extends BaseTypeHandler<List<CalendarItemVO>> {
private static final ObjectMapper mapper = new ObjectMapper();
@Override
public void setNonNullParameter(PreparedStatement ps, int i, List<CalendarItemVO> parameter, JdbcType jdbcType) throws SQLException {
ps.setString(i, toJson(parameter));
}
@Override
public List<CalendarItemVO> getNullableResult(ResultSet rs, String columnName) throws SQLException {
return fromJson(rs.getString(columnName));
}
@Override
public List<CalendarItemVO> getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
return fromJson(rs.getString(columnIndex));
}
@Override
public List<CalendarItemVO> getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
return fromJson(cs.getString(columnIndex));
}
private String toJson(List<CalendarItemVO> object) {
try {
return mapper.writeValueAsString(object);
} catch (JsonProcessingException e) {
throw new RuntimeException(e);
}
}
private List<CalendarItemVO> fromJson(String json) {
try {
return mapper.readValue(json, new TypeReference<List<CalendarItemVO>>() {});
} catch (IOException e) {
throw new RuntimeException(e);
}
}
}
```
在这个 TypeHandler 中,我们使用 ObjectMapper 类将 LinkedHashMap 转换为 List<CalendarItemVO> 对象。然后,在你的实体类中,你需要在对应的字段上使用 @TypeHandler 注解,指定使用这个 TypeHandler。例如:
```java
@TableField(typeHandler = JacksonTypeHandler.class)
private List<CalendarItemVO> calendarData;
```
这样,当你查询这个字段时,得到的就是一个 List<CalendarItemVO> 对象,你就可以遍历这个集合了。
阅读全文