JdbcTemplate之如何查询返回对象的集合

今天看JdbcTemplate时,写了两个测试方法,一个插入和一个查询所有的结果集,插入没有任何问题,查询时遇到点问题,后来找到问题和所在和解决办法:

查询时调用了JdbcTemplate的queryForList方法,原API中如下:
@Override
 public <T> List<T> queryForList(String sql, Class<T> elementType) throws DataAccessException {
      return query(sql, getSingleColumnRowMapper(elementType));
 }
所以想着很简单,传一个查询的sql和返回对象类型即可,结果并不行,报org.springframework.jdbc.IncorrectResultSetColumnCountException: Incorrect column count: expected 1, actual 4,意思预期1行,返回了4行,经过查看JdbcTemplatequeryForList方法的源码,发现第二个参数是@param elementType the required type of element in the result list(for example, {@code Integer.class}),百度翻译后是:所需的元素类型的元素列表的结果(例如,代码integer.class“{ }),也就是说只支持String、Integer这些单数据类型的,不支持我们自定义的对象类型。
所以只能用其他方法获取了,看API有个方法:
@Override
 public <T> List<T> query(String sql, RowMapper<T> rowMapper) throws DataAccessException {
      return result(query(sql, new RowMapperResultSetExtractor<>(rowMapper)));
 }
第二个参数的意思是将返回的列映射到对应实体类的属性,需要我们自定义实现,RowMapper是一个接口,我们只需要让我们的实体类实现该接口,重写mapRow方法,定义好自己的映射关系,传入实体类作为参数即可。
例如:实体类User实现RowMapper接口,重写方法如下
@Override
 public User mapRow(ResultSet rs, int rowNum) throws SQLException {
  User user = new User();
  user.setId(rs.getInt("id"));
  user.setName(rs.getString("name"));
  user.setAge(rs.getInt("age"));
  return user;
 }

插入时使用List<User> users = jdbcTemplate.query("select * from user", new User());这样就可以实现查询返回对象的集合。


以下是一个示例代码,演示如何使用JdbcTemplate查询返回一个List对象: ```java import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.jdbc.core.RowMapper; import java.util.List; public class MyDao { private JdbcTemplate jdbcTemplate; // 注入JdbcTemplate对象 // 查询所有用户 public List<User> findAllUsers() { String sql = "SELECT * FROM user"; RowMapper<User> rowMapper = new UserRowMapper(); // 定义一个RowMapper对象,用于将ResultSet转换为User对象 // 调用JdbcTemplate的query方法执行查询,并将结果集转换为List<User>对象 List<User> users = jdbcTemplate.query(sql, rowMapper); return users; } // 定义一个内部类,实现RowMapper接口,用于将ResultSet转换为User对象 private class UserRowMapper implements RowMapper<User> { @Override public User mapRow(ResultSet rs, int rowNum) throws SQLException { User user = new User(); user.setId(rs.getInt("id")); user.setName(rs.getString("name")); user.setEmail(rs.getString("email")); return user; } } } ``` 在上面的示例中,我们定义了一个MyDao类,其中包含一个findAllUsers方法,用于查询所有用户数据并返回List<User>对象。在该方法中,我们使用JdbcTemplate的query方法执行查询,并将结果集转换为List<User>对象。为了将ResultSet转换为User对象,我们定义了一个内部类UserRowMapper,实现了RowMapper接口,用于将ResultSet中的数据映射到User对象中。最后,我们返回查询结果集的List对象
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值