之前做一个数据移植的工具,从一个数据库移植数据到另一个数据库,但是表结构不同,只能通过代码实现这个业务逻辑,具体的业务逻辑就不说了,从对象内一个个去get,set不方便,也降低了我们程序员的素质,so,我写了一个工具类;
前提:针对实体内含有多个父类情况。
public static void getFileds(Object classA,Class<?> clazzA,Object classB,Class clazzB){
Map map =new HashMap();
Class<?> superClass=clazzA.getSuperclass();
if(superClass.equalds(Object.class)){
//如果父类不是Objcet类,那表示该类继承了自定义类,则执行递归操作。
getFileds(classA,superClass,classB,clazzB);
}
//没有父类,执行以下代码
Filed[] classBFileds=clazzB.getDeclareFiled();
Filed claA;
for(Filed classBFiled : classBFileds){
classBFiled.setAccessible(true);
String name=classBFiled .getName();
try{
//判断当前类是否有次属性名
PropertyDescriptor pd=new PropertyDescriptor (name,clazzB);
Method readMethod=pd.getReadMethod();
claA=clazzA.getDeclaredField(name);
claA.setAccessible(true);
claA.set(classA,readMethod.invoke(classB));
}catch(exception e){
//没有的话跳过此属性
continue;
}
}
}
就是这么简单,通过递归,实现所有实体的赋值动作。