如何把ResultSet转换成Java对象

2025-01-18 18:56:08
推荐回答(2个)
回答1:

首先定义一个实体类对象User
public class User {
private int id;
private String name;
private String password;

/*
省略set,get方法
*/
}

例如执行查询操作
Connection conn=null;
PreparedStatement pst=null;
ResultSet rs=null;
String sql="select * from user";
List list=new ArrayList();
try {
conn=new jdbc().DBConnect();
pst=conn.prepareStatement(sql);
rs=pst.executeQuery();
while(rs.next()){
User user=new User();
user.setId(rs.getInt("id"));
        user.setName(rs.getString("name"));
user.setPassword(rs.getString("password"));
list.add(user);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
查询出来的结果集是resultset,分别取其中的元素并赋值给声明的实体变量user
再把user放到list集合中,这样就完成了取值和转化

回答2:

一种方法是根据resultSet返回值与表列的顺序对应的位置,顺序地为对象的属性赋值

还可以使用ResultSetMapper这个类的mapRersultSetToObject方法