利用反射给hibernate实体类赋值

今天做到一个excel导入的业务,可以对excel进行配置,决定要导入哪些字段,但是配置项里只能拿到数据库的原始字段,然后我就做了一个利用原始字段通过反射给Entity类赋值的方法

下面是全部代码

public class ReflectUtils {
	public static String getFieldColumn(Class clazz,String columnName) throws Exception {
    	Field[] field = clazz.getDeclaredFields();
    	for(Field f:field) {
    		boolean fieldHasAnno = f.isAnnotationPresent(Column.class);  
    		if(fieldHasAnno) {
    			Column column = f.getAnnotation(Column.class);
    			if(column.name().equals(columnName))
    				return f.getName();
    		}
    		String fieldName =f.getName();
    		fieldName = "get"+fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);
    		Method method = getDeclaredMethod(clazz, fieldName);
    		if(method == null)
    			continue;
    		Column column = method.getAnnotation(Column.class);
    		if(column.name().equals(columnName))
				return f.getName();
    	}
    	return "";
    }
	public static Method getDeclaredMethod(Class clazz,String methodName) {
		try {
			return clazz.getDeclaredMethod(methodName);
		} catch (NoSuchMethodException e) {
		}
		return null;
	}
	public static <T> T setField(T t, String columnName, Object o) throws Exception{
		String fieldName = getFieldColumn(t.getClass(), columnName);
		Field f = t.getClass().getDeclaredField(fieldName);
		f.setAccessible(true);
		f.set(t, o);
		return t;
	}
	public static void main(String[] args) throws Exception {
		ProductModel p = new ProductModel();
		setField(p, "partnum","产品1");
		System.out.println(p.getPartNum());
	}
}
下面的方法参数是类和原始字段名,遍历类中的变量,对比变量的column标签的name值,如果相同则返回对应的变量名
public static String getFieldColumn(Class clazz,String columnName) throws Exception {
    	Field[] field = clazz.getDeclaredFields();
    	for(Field f:field) {//遍历类中有的变量
    		boolean fieldHasAnno = f.isAnnotationPresent(Column.class);  
    		if(fieldHasAnno) {//判断变量上是否有column标签,如果有那么判断是否跟原始值相同
    			Column column = f.getAnnotation(Column.class);
    			if(column.name().equals(columnName))//相同则返回
    				return f.getName();
    		}
    		String fieldName =f.getName();//如果变量上没有标签,那么判断get方法上有没有标签
    		fieldName = "get"+fieldName.substring(0, 1).toUpperCase() + fieldName.substring(1);
    		Method method = getDeclaredMethod(clazz, fieldName);//将获得get方法的方法封装,防止报错
    		if(method == null)
    			continue;
    		Column column = method.getAnnotation(Column.class);
    		if(column.name().equals(columnName))
				return f.getName();
    	}
    	return "";
    }

先调用getFieldColumn获得变量名,然后利用反射直接赋值

	public static <T> T setField(T t, String columnName, Object o) throws Exception{
		String fieldName = getFieldColumn(t.getClass(), columnName);
		Field f = t.getClass().getDeclaredField(fieldName);
		f.setAccessible(true);
		f.set(t, o);
		return t;
	}
以上

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值