赞
踩
java.util.LinkedHashMap cannot be cast to com.entity.Person
使用mybatis, resultMap映射的是实体类Person, 查询出来的结果是一个ArrayList,然后结果存放在一个ListObject的data属性中,
存放结果的类
public class ListObject {
private Object data;
public Object getData() {
return data;
}
public void setData(Object data) {
this.data = data;
}
}
强制转换成List result = (List)result.getData();没有报错, 也拿到了数据,当使用for循环的时候报错 java.util.LinkedHashMap cannot be cast to com.entity.Person
ListObject result = method.query(name);
List result = (List)result.getData();
for(Person per : result){
sourceList.add(per .getId());
}
解决方法:
导入 net.sf.json 类,使用JSONObject中的方法, 先将数据转成json字符串, 在转成实体对象
ListObject result = method.query(name);
List result = (List)result.getData();
for(Object obj : result){
JSONObject jsonObject=JSONObject.fromObject(objectStr);
Person per = (Person)JSONObject.toBean(jsonObject, Person.class);
sourceList.add(per.getId());
}
主要就是两步
JSONObject jsonObject=JSONObject.fromObject(objectStr); // 将数据转成json字符串
Person per = (Person)JSONObject.toBean(jsonObject, Person.class); //将json转成需要的对象
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。