• 利用反射把数据集合转换成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;
    }
    
     
  • 相关阅读:
    存储过程
    Apache服务器
    SpringMVC (<context:include-filter>和<context:exclude-filter>的使用)
    虚拟机centos 同一个tomcat、不同端口访问不同的项目
    CentOS系统下搭建tomcat服务器
    nginx配置负载均衡
    配置plsql远程连接oracle数据库
    Nginx安装
    Centos6.5系统关闭防火墙
    禁止Centos7系统yum自动下载更新
  • 原文地址:https://www.cnblogs.com/dashi/p/4260392.html
Copyright © 2020-2023  润新知