自定义Dbutils

1、

package cn.itcast.frame.utils;


import java.lang.reflect.Field;
import java.sql.ResultSet;
import java.sql.ResultSetMetaData;


/*
 * "select * from account where id=?"--> 一条记录
     Java中: Account a 
              情况二: ResultSet只有一条记录,将这条记录封装到一个JavaBean中      
              处理器: BeanHandler   implements ResultSetHandler  
 */
public class BeanHandler implements ResultSetHandler {


private Class clazz;
    /**
     * 
     * @param clazz: 将结果集中的记录封装到该类的一个实例中
     */
public BeanHandler(Class clazz){
this.clazz = clazz;
}

@Override
public Object handler(ResultSet rs) {
if(rs == null){
return null;
}

//定义该类的一个实例
Object instance = null;
try {
//创建该类的实例
instance = clazz.newInstance();

//取出结果集中元数据(结果集的元数据)
ResultSetMetaData metaData = rs.getMetaData();

//结果集中的列数
int columnCount = metaData.getColumnCount();

if(rs.next()){
//取出该行上的每个列
for(int i=0;i<columnCount;i++){
//该列的名字
String columnName = metaData.getColumnName(i+1);
//取该列的值
Object value = rs.getObject(columnName);

//得到该类clazz的某个属性
Field f = clazz.getDeclaredField(columnName);

//暴力反射
f.setAccessible(true);

//将该值放到该属性上

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值