Spring JdbcTemplate query查询结果转换对象

在使用JdbcTemplate的时候,可以使用query方法来查询指定的sql语句,来返回我们需要的结果。query提供了RowMapper接口,可以方便的将查询结果转换为对象。

RowMapper常见的有2个实现类BeanPropertyRowMapper和EntityRowMapper。在使用上,位置是等价的。

//BeanPropertyRowMapper
List<T> list = jdbcTemplate.query(sql, new Object[] {param1,param2...}, new BeanPropertyRowMapper<>(T.class)) 
//EntityRowMapper
List<T> list = jdbcTemplate.query(sql, new Object[] {param1,param2...}, new EntityRowMapper<>(T.class));
BeanPropertyRowMapper可以是我们自定义的一个普通类,但是属性需要和返回的列名是一致。

EntityRowMapper则需要是由Entity注解的实体类。属性定义的Column的Name和返回的列名一致。

如果是查询select *,那么可以直接使用实体类的EntityRowMapper,其他情况,可以自定义的类来取值。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是一个示例代码,演示如何使用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对象 // 调用JdbcTemplatequery方法执行查询,并将结果集转换为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>对象。在该方法中,我们使用JdbcTemplatequery方法执行查询,并将结果集转换为List<User>对象。为了将ResultSet转换为User对象,我们定义了一个内部类UserRowMapper,实现了RowMapper接口,用于将ResultSet中的数据映射到User对象中。最后,我们返回了查询结果集的List对象

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值