java减少数据访问层代码—反射2—将ResulSet动态转成get、set

package com.fendou.wrapper;

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Type;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
/**
 * 2012-9-18
 * @author 牟云飞
 *
 */
public class WrapperBatcher<T> {
 
 /**
  * 方法一:将resultSet自动变成对应的类
  * 方法二优秀,方法一再某些条件下是错误的,例如:get、set一旦调用顺序变动
  * 都是set
  * @param 类的完整路径
  * @param resultSet结果集
  * @return 对应的类
  */
 public T setWrapper(String classPath,ResultSet rs){
  T t = null;
  try {
   Class cl = Class.forName(classPath);
   //得到这个类的所有成员
   Field[] name = cl.getDeclaredFields();
   //得到这个类中所有的方法
   Method[] method = cl.getDeclaredMethods();
   //实例化
   t = (T) cl.newInstance();
   //调用set设置值
   for(int i =0;i<method.length;i++){
    if(method[i].getName().startsWith("set")){
     int h =0;
     if(((i/2)-1)<=0){
      h=0;
     }else{
      h=i/2-1;
     }
     String type=name[h].getType().getName();
              type = type.substring(type.lastIndexOf(".")+1,type.length());
              System.out.println(type+"   "+method[i].getName());
     if(type.toString().equals("int")){
      if(rs.getInt(method[i].getName().toLowerCase().substring(3,method[i].getName().length()))!=0){
       method[i].invoke(t,rs.getInt(method[i].getName().toLowerCase().substring(3,method[i].getName().length())));
      }else{
       method[i].invoke(t,0);
      }
     }else if(type.toString().toLowerCase().equals("string")){
      if(rs.getString(method[i].getName().toLowerCase().substring(3,method[i].getName().length()))!=null){
       method[i].invoke(t,rs.getString(method[i].getName().toLowerCase().substring(3,method[i].getName().length())));
      }
     }else if(type.toString().toLowerCase().equals("date")){
      if(rs.getString(method[i].getName().toLowerCase().substring(3,method[i].getName().length()))!=null){
       method[i].invoke(t,rs.getDate(method[i].getName().toLowerCase().substring(3,method[i].getName().length())));
      }
     }else if(type.toString().toLowerCase().equals("double")){
      if(rs.getDouble(method[i].getName().toLowerCase().substring(3,method[i].getName().length()))!=0){
       method[i].invoke(t,rs.getDouble(method[i].getName().toLowerCase().substring(3,method[i].getName().length())));
      }else
      {
       method[i].invoke(t,0.0);
      }
     }
    }
   }
   
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (InstantiationException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IllegalAccessException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IllegalArgumentException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (InvocationTargetException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } 
  return t;
 }
 
 /**
  * 方法二:将resultSet自动变成对应的类
  * 都是set
  * @param 类的完整路径
  * @param resultSet结果集
  * @return 对应的类
  */
 public T setT(String classpath,ResultSet rs){
  T t = null;
  try {
  Class classType = Class.forName(classpath);
   //得到这个类的所有成员
  Field[] name = classType.getDeclaredFields();
   //得到这个类中所有的方法
  Method[] method = classType.getDeclaredMethods();
   //实例化
  t = (T) classType.newInstance();
  // 获得对象的所有属性
        Field fields[] = classType.getDeclaredFields();

        for (int i = 0; i < fields.length; i++) {
            Field field = fields[i];

            String fieldName = field.getName();
            String firstLetter = fieldName.substring(0, 1).toUpperCase();

//            // 获得和属性对应的getXXX()方法的名字
//            String getMethodName = "get" + firstLetter + fieldName.substring(1);
            // 获得和属性对应的setXXX()方法的名字
            String setMethodName = "set" + firstLetter + fieldName.substring(1);

//            // 获得和属性对应的getXXX()方法
//            Method getMethod = classType.getMethod(getMethodName,new Class[] {});
   
            // 获得和属性对应的setXXX()方法,使用filed对象的类型
            Method setMethod = classType.getMethod(setMethodName,new Class[] { field.getType() });

//            // 调用原对象的getXXX()方法:指定调用的对象和方法的参数值列表
//            Object value = getMethod.invoke(t, new Object[] {});
//            System.out.println(fieldName + ":" + value);
            // 调用拷贝对象的setXXX()方法:指定调用的对象和参数值列表(注意必须是Object类型)
            String type=field.getType().getName();
            type = type.substring(type.lastIndexOf(".")+1,type.length());
            if(type.toString().equals("int")){
             if(rs.getInt(field.getName())!=0){
               setMethod.invoke(t,rs.getInt(field.getName()));
             }
   }
            if(type.toString().equals("String")){
             if(rs.getString(field.getName())!=null){
              setMethod.invoke(t,rs.getString(field.getName()));
             }
   }
            if(type.toString().equals("Date")){
             if(rs.getDate(field.getName())!=null){
              setMethod.invoke(t,rs.getTimestamp(field.getName()));
             }
      }
            if(type.toString().equals("Double")){
             if(rs.getDouble(field.getName())!=0){
              setMethod.invoke(t,rs.getDouble(field.getName()));
       }
      }
        }
  } catch (SecurityException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (NoSuchMethodException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IllegalArgumentException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (IllegalAccessException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (InvocationTargetException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (ClassNotFoundException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (InstantiationException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  } catch (SQLException e) {
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
        return t;
 }
 
 
 
}


 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

牟云飞

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值