java减少数据访问层代码—反射1—数据访问层Wrapper

来源:互联网 发布:nginx tomcat https 编辑:程序博客网 时间:2024/04/30 23:08

 

           如果不用生成器生成的话,在每一次写数据访问层的时候都需要这样写

其中的getset有相当的多,并且容易敲错,代码量有比较多,这时候可以将这个getset进行封装,那么首先先了解下所需要的一些类和方法

1Class cl = Class.forName(classPath);这个就不必再说,在数据连接时大家都看过了


2//得到这个类的所有成员
        Field[] name = cl.getDeclaredFields();

       得到成员有什么用呢,这样就可以

      

            String fieldName = field.getName();
            String firstLetter = fieldName.substring(0, 1).toUpperCase();
            // 获得和属性对应的方法的名字
            String setMethodName = "set" + firstLetter + fieldName.substring(1);

    这样就得到对用的方法名了

 

3  // 获得和属性对应的方法

           Method setMethod = classType.getMethod(setMethodName,new Class[] { field.getType() });

         就可以用第2步的名字生成对应的方法   

 



4   //实例化一个对象,T是什么呢,是一个泛型
         t = (T) cl.newInstance();

 

5   //调用方法将值动态写入

       setMethod.invoke(t,rs.getInt(field.getName()));       

   

6  //得到这个类中所有的方法
          Method[] method = cl.getDeclaredMethods();

 

这就是用的一些主要的类和方法,包都是java.lang.reflect里的

import java.lang.reflect.Field;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.lang.reflect.Type;

 

封转完成后获取全部数据就可以

/**
  * 得到所有的订单
  */
 public List<Orders> getAllOrders() {
  List<Orders> list = new ArrayList<Orders>();
  Orders or= new Orders();
  String sql = "select * from Orders";
  list = db.getResultList("com.fendou.vo.Orders", sql);
  return list;
 }

所有的代码变得简单多了