JdbcTemplate自定义映射器

本文介绍如何在数据库字段与对象属性不一致时,通过自定义映射器将结果集转换为所需对象的过程。提供了AccountRowMapper的具体实现代码,以及使用JdbcTemplate进行数据库操作并测试映射器功能的示例。
摘要由CSDN通过智能技术生成

(1)作用:结果集映射器BeanPropertyRowMapper的使用前提是数据库字段和对象属性
一致,
当不一致的时候,使用自定义映射器解决,将结果集转换成需要的对象
(2)自定义映射器代码如下

public class AccountRowMapper implements RowMapper<Account> {
/**
* 需要手动将结果集封装成对象
* @param rs 结果集(数据库里的字段)
* @param i 结果集所在的行: 下标从0开始
* @return 封装好的对象
* @throws SQLException
*/
@Override
public Object mapRow(ResultSet rs, int i) throws SQLException {
//1、新建实体类对象
Account account = new Account();
//2、设置属性值
account.setId(rs.getInt("id"));
account.setUid(rs.getInt("uid"));
account.setMoney(rs.getDouble("money"));
//不同的字段(这里数据库没有,实体类有的字段)
account.setUserId(rs.getInt("id"));
//3、返回对象
return account;
 }
 }

(3)测试映射器代码如下

@Test
 public void testCustomMapper(){
 //1、创建容器
 ClassPathXmlApplicationContext ioc =
 new ClassPathXmlApplicationContext("applicationContext.xml");
 //2、获取工具类对象
 JdbcTemplate jd = ioc.getBean(JdbcTemplate.class);
 //3、操作数据库
String sql = "select * from account";
 List accountList = jd.query(sql, new AccountRowMapper());
 accountList.forEach(System.out::println);
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值