【JavaEE_练习】resultset转list输出

import org.apache.commons.lang3.StringUtils;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.sql.*;
import java.util.*;


public class Resulttobean {
    //此方法适用于任意bean
    public static List<Object> resulttobean(ResultSet rs,Class clazz) throws Exception {
        List<Object> list=new ArrayList();
        while(rs.next()){
            Object obj =  clazz.newInstance();
            ResultSetMetaData metaData = rs.getMetaData();
            int columnCount = metaData.getColumnCount();
            for(int i=0;i<columnCount;i++){
                //获取列名
                String columnName = metaData.getColumnName(i+1);
                String methodname="set"+ StringUtils.capitalize(columnName);
                //得到列值
                Object value = rs.getObject(columnName);
                Field field = clazz.getDeclaredField(StringUtils.lowerCase(columnName));
                Method method = clazz.getMethod(methodname, field.getType());
                //执行bean的setXX方法
                method.invoke(obj, value);
            }
            list.add(obj);
        }
        return list;

    }
    public static ResultSet getResult() throws ClassNotFoundException, SQLException {
        Class.forName("com.mysql.jdbc.Driver");
        String url="jdbc:mysql:///mybase";
        String username="root";
        String password="1234";
        Connection connection = DriverManager.getConnection(url, username, password);
        String sql="select * from todo";
        PreparedStatement preparedStatement = connection.prepareStatement(sql);
        ResultSet resultSet = preparedStatement.executeQuery();

        return resultSet;
    }

    public static void main(String[] args) throws Exception {
        ResultSet result = getResult();
        Class<?> aClass = Class.forName("org.westos.resulttobean.Todo");
        List<Object> resulttobean = resulttobean(result, aClass);
        System.out.println(resulttobean);
    }
}

Bean:

package org.westos.resulttobean;

public class Todo {
    private Integer id;
    private String title;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    @Override
    public String toString() {
        return "Todo{" +
                "id=" + id +
                ", title='" + title + '\'' +
                '}';
    }
}

运行结果:
这里写图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值