beanUtils 在使用BeanHandle 和BeanListHandle查询数据进行自定义对象映射

本文介绍两种解决BeanUtils映射时表列名与对象属性名不一致的问题:一是通过SQL别名映射;二是通过继承BeanHandle和BeanListHandle类,并结合注解实现自定义映射。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

beanUtils 在使用BeanHandle 和BeanListHandle查询数据进行自定义对象映射时,如果表的列名和对象属性名不一样,是不能映射映射到对象上的
本文就是介绍两种方法来解决这个问题。
注:本文适合对beanUtils有一定了解的人阅读,网上有很多beanUtils基础资料的介绍,我就不赘述了。


一,通过写sql来处理。
该方法比较简单当QueryRunner来查询数据时,必须要传入sql,在查询时只要将数据库表查询出的字段的别名设定为对象的属性名就可以直接映射
 

如:

User表

u_idu_name
..........


User对象

public class User {
    private String id;
    private String name;
    ......
}


sql 可以这样写 select u_id as id,u_name as name from User 
这样查询出来的数据就可以直接映射为对象了。
该种方法的特点:通过sql直接映射,如果查询的字段不多,使用该表查询的地方也不多,使用这种方法时比较简单的。


二,第二种方法就是继承BeanHandle类和BeanListHandle类复写handle方法并结合xml配置或注解来解决这个问题。
下面结合注解来讲解。

 

 

1,注解类

 

 

_________________________________________________________________

package com.until.annotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
/**
 *
 * 与数据库对应的列字段注解
 */
@Target({ElementType.FIELD})
@Retention(RetentionPolicy.RUNTIME)
public @interface Column {
    String value();
}


_________________________________________________________________
 

2,自定义BetterBeanHandle 继承BeanHandle,复写handle方法

_________________________________________________________________

package com.until.dbUtilsHandle;
import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.SQLException;
import org.apache.commons.dbutils.handlers.BeanHandler;
import com.until.annotation.Column;
/**
 * 复写BeanHandler的handle方法,获取注解字段映射
 * @author 
 *
 */
public class BetterBeanHandle<T> extends BeanHandler<T>{
private Class<T> calzz;
public BetterBeanHandle(Class<T> type) {
super(type);
this.calzz=type;
}

@Override
public T handle(ResultSet rs) throws SQLException {
    Field[] fields = calzz.getDeclaredFields();//反射获取字段属性
    T t=null;
    try {
        if (rs.next()) {
            //如果结果集存在数据,反射新建一个对象。
            t = calzz.newInstance();
            //将结果集数据映射到对象的每个有注解的字段上
            for (Field field : fields) {
                field.setAccessible(true);
                //获取注解字段
                Column column = field.getAnnotation(Column.class);
                判断该字段是否有注解,如果有,才获取其值,也即你查询出来的数据,如果没有在对象字段写注解,是不会映射的,但也不报错。
                if (column!=null) {
                    //获取注解值,业绩表字段名
                    String colVal = column.value();
                    //为对象属性值设值,rs.getObject(colVal)表示从结果集中查询出的列明对应的值。
                    field.set(t, rs.getObject(colVal));
                }
            }
        }
    } catch (Exception e) {
        e.printStackTrace();
    } 
    return t;
}
}

_______________________________________________________________

 

3,自定义BetterBeanListHandle 继承BeanListHandle,复写handle方法

_________________________________________________________________

package com.until.dbUtilsHandle;
import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import com.until.annotation.Column;
/**
 * 复写handle方法,获取注解字段映射
 */
public class BetterBeanListHandle<T> extends BeanListHandler<T>{
private Class<T> clazz;
public BetterBeanListHandle(Class<T> type) {
super(type);
this.clazz=type;
}
@Override
public List<T> handle(ResultSet rs) throws SQLException {
List<T> list = new ArrayList<T>();
T obj = null;
try {
while (rs.next()) {
// 1. 对象
obj = clazz.newInstance();
// 2. 对象属性
Field[] fs = clazz.getDeclaredFields();
for (Field f : fs) {
f.setAccessible(true);
// 获取属性上的注解
Column column = f.getAnnotation(Column.class);
if (column!=null) {
// 获取字段名称
String columnName = column.value();
// 获取字段名称, 对应的值
Object columnValue = rs.getObject(columnName);
f.set(obj, columnValue);
}

}
// 对象添加到list集合
list.add(obj);
}
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
}
______

___________________________________________________________
 

4,使用注解的User类

_________________________________________________________________

public class User {
    @Column("u_id")
    private String id;
    @Column("u_name")
    private String name;
}


_________________________________________________________________

5,这样在查询所有数据时sql可以直接写为select * from User
QueryRunner qr=new QueryRunner(dataSource);//dataSource表示传入的数据源
List<User> users = qr.query(sql, new BetterBeanListHandle<User>);//查询时使用自己定义的handle类就可以了,查询单条数据类似。
该种方法的特点:这种方法有点类似hibernate的注解映射,如果在很多地方都要遇到该表的查询,而且查询的字段较多,写sql麻烦,用这种方法会简答一些。



























































 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值