java.util.LinkedHashMap cannot be cast to com.entity.Person
使用mybatis, resultMap映射的是实体类Person, 查询出来的结果是一个ArrayList<Person>,然后结果存放在一个ListObject的data属性中,
存放结果的类
public class ListObject { private Object data; public Object getData() { return data; } public void setData(Object data) { this.data = data; } }
强制转换成List<Person> result = (List<Person>)result.getData();没有报错, 也拿到了数据,当使用for循环的时候报错 java.util.LinkedHashMap cannot be cast to com.entity.Person
ListObject result = method.query(name); List<Person> result = (List<Person>)result.getData();
for(Person per : result){ sourceList.add(per .getId()); }
解决方法:
导入 net.sf.json 类,使用JSONObject中的方法, 先将数据转成json字符串, 在转成实体对象
ListObject result = method.query(name);
List<Person> result = (List<Person>)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转成需要的对象
net.sf.ezmorph.bean.MorphDynaBean cannot be cast to xxx
当需要转换的json中包含有集合的时候, 需要先建一个map,将需要转换的对象中的集合中的对象放进map, 然后使用JSONObject.toBean(jsonObject,Person.class,maps);进行转换.
具体操作:
teacher类中有一个List<Student> stu, 当需要转化teacher时, 就需要多写一个map对象
import java.util.List; /** * @author xukai * */ public class Teacher { private String teaId; private String teaName; private List<Student> stu; public Teacher() { } //getter setter }
JSONObject jsonObectj = JSONObject.fromObject(teacher);
Map<String, Class> map = new HashMap<String,Class>(); map.put("stu", Student.class); // key为teacher私有变量的属性名 如果有多个集合需要转换, 写多个map.put()即可
Teacher teacherBean = (Teacher) JSONObject.toBean(jsonObectj, Teacher.class, map);
主要就是在原先的方法基础上, 加一个map, 用来存集合转换的类型