RowMapper 使用

public List selectSql(){

String baseSql="";		
baseSql="SELECT * from "+tableName ;

			
		

//通过反射进行映射,查出实体类集合
List query = jdbcTemplate.query(baseSql, new RowMapper<Object>() {
	@Override
	public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
	Class aClass = map.get(tableName);
	Object obj = BeanUtils.instantiateClass(aClass);//实例化类
	Field[] fields = aClass.getDeclaredFields();//获取类的bean
	for (Field field:fields){
		field.setAccessible(true);//成员变量置为private 时,需要设置
		if (field.isAnnotationPresent(Column.class)){
			Column cloumn = field.getAnnotation(Column.class);//获取注解上的信息
				try {
				Class<?> type = field.getType();//获取属性类型
			String simpleName = type.getSimpleName();//获取属性类型的名称,如:String
				if (simpleName.equalsIgnoreCase("String")){
				field.set(obj,rs.getString(cloumn.name()));//设置将对应的列赋值给实体类
							}
	if (simpleName.equalsIgnoreCase("Integer")||simpleName.equalsIgnoreCase("int")){
								field.set(obj,rs.getInt(cloumn.name()));
							}
							if (simpleName.equalsIgnoreCase("Boolean")){
								field.set(obj,rs.getBoolean(cloumn.name()));
							}
							if (simpleName.equalsIgnoreCase("Long")){
								field.set(obj,rs.getLong(cloumn.name()));
							}
							if (simpleName.equalsIgnoreCase("Double")){
								field.set(obj,rs.getDouble(cloumn.name()));
							}
							if (simpleName.equalsIgnoreCase("Float")){
								field.set(obj,rs.getFloat(cloumn.name()));
							}
							if (simpleName.equalsIgnoreCase("Date")){
								field.set(obj,rs.getDate(cloumn.name()));
							}

						} catch (IllegalAccessException e) {
							e.printStackTrace();
						}
					}
				}
				return obj;
			}
		});

		return  query;
	}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值