jdbcTemplate.queryForList 错误 spring-org.springframework.jdbc.IncorrectResultSetColumnCountException

本文探讨了在使用Spring jdbcTemplate的queryForList方法时遇到的IncorrectResultSetColumnCountException异常,详细介绍了错误代码及如何通过自定义BeanPropertyRowMapper解决此问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用queryForList想要获取一个List<T>时,使用jdbcTemplate.queryForList(Sql,T.class);

会报IncorrectResultSetColumnCountException错误,而使用

//SQL语句
String SQL_SELECT = "select * from stu;";

错误代码如下:

//错误代码 IncorrectResultSetColumnCountException: Incorrect column count: expected 1, actual 9
jdbcTemplate.queryForList(SQL_SELECT,Student.class);
//返回结果不符合预期 maps
List<Map<String, Object>> maps = jdbcTemplate.queryForList(SQL_SELECT, new BeanPropertyRowMapper<Student>());

自己想了半天没想出来,后来再网上查了一些解决了问题:

//执行并返回结果
students = jdbcTemplate.query(SQL_SELECT,new BeanPropertyRowMapper<Student>(Student.class));

不使用他所提供的queryForList,自己使用query然后重写BeanPropertyRowMapper,就能实现获取List的方法了

如果有比这个更简单的,希望你能教教我。                            

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值