利用反射把数据集合转换成List
---ResultSet数据集
public static List toList(ResultSet rs, Class cls) { List list = new ArrayList(); try { BeanInfo beanInfo = Introspector.getBeanInfo(cls); // 获取类属性 // 给 JavaBean 对象的属性赋值 PropertyDescriptor[] propertyDescriptors = beanInfo .getPropertyDescriptors(); ResultSetMetaData meta = rs.getMetaData(); Object obj = null; while (rs.next()) { obj = cls.newInstance(); // 创建 JavaBean 对象 for (int j = 1; j <= meta.getColumnCount(); j++) { for (int i = 0; i < propertyDescriptors.length; i++) { PropertyDescriptor descriptor = propertyDescriptors[i]; String propertyName = descriptor.getName(); String propertyType = descriptor.getPropertyType() .getName(); if (meta.getColumnName(j) .equalsIgnoreCase(propertyName)) { Method method = descriptor.getWriteMethod(); Object value = rs.getObject(j); if (propertyType.equals("java.lang.String") && value == null) { method.invoke(obj, ""); } else if (propertyType.equals("java.lang.String")) { method.invoke(obj, value.toString()); } else if (propertyType.equals("java.util.Date")) { method.invoke(obj, (Date) value); } else if (propertyType.equals("java.lang.Integer")) { method.invoke(obj, new Integer((String) value)); } else if (propertyType.equals("float")) { method.invoke(obj, Float.parseFloat((String) value)); }else if(propertyType.equals("java.math.BigDecimal")) { method.invoke(obj,(BigDecimal)value); } else { method.invoke(obj, value); } break; } } } list.add(obj); } } catch (Exception ex) { ex.printStackTrace(); } finally { return list; } } }
---Map数据集
public static Object convertMap(Class type, Map map) { Object obj = null; try { BeanInfo beanInfo = Introspector.getBeanInfo(type); // 获取类属性 obj = type.newInstance(); // 创建 JavaBean 对象 // 给 JavaBean 对象的属性赋值 PropertyDescriptor[] propertyDescriptors = beanInfo .getPropertyDescriptors(); // 获取key的集合 Set<String> keySet = map.keySet();// 获取mapKEY for (int i = 0; i < propertyDescriptors.length; i++) { PropertyDescriptor descriptor = propertyDescriptors[i]; String propertyName = descriptor.getName(); String strPropertyName = propertyName.toLowerCase();// 大写转小写 String propertyType=descriptor.getPropertyType().getName(); // 遍历key集合,获取value for (String key : keySet) { String strKey = key.toLowerCase(); if (strPropertyName.equals(strKey)) {// 对比key与属性是否相同 // 下面一句可以 try 起来,这样当一个属性赋值失败的时候就不会影响其他属性赋值。 Object value = map.get(key); /* Object[] args = new Object[1]; args[0] = value;*/ Method method= descriptor.getWriteMethod(); if(propertyType.equals("java.lang.String")){ method.invoke(obj,value.toString()); } else if(propertyType.equals("java.util.Date")){ method.invoke(obj, (Date)value); } else if(propertyType.equals("java.lang.Integer")){ method.invoke(obj, new Integer((String)value)); } else if(propertyType.equals("float")){ method.invoke(obj, Float.parseFloat((String)value)); } else{ method.invoke(obj, value); } break; } } } } catch (Exception e) { // TODO: handle exception logger.error("map转换对象错误", e); } return obj; }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步