hibernate查询实体类List,及传参报错Mapped class was not specified

调用Hibernate的方法执行查询到List<实体类>中,
看到如下方法:在这里插入图片描述
乍一看,我想传个泛型T(实际代码执行中,这个T可以是我自定义的一个Bean),然后就能返回个List,也即泛型的集合
执行代码:
List<Student> list = jdbcTemplate.queryForList(sql, Student.class);
一执行,发现出异常了:
ERROR [com.ruhuiyun.studentmanager.aop.LogAdvice] - org.springframework.jdbc.IncorrectResultSetColumnCountException: Incorrect column count: expected 1, actual 8:Incorrect column count: expected 1, actual 8
异常很明了,需要一个,给人家整成了八个,也就是人家不是存List的。甚为蹊跷,后一查,发现不是这样的~
在这里插入图片描述
原来这个T,只支持Integer.class String.class 这种单数据类型的,自己定义的Bean不支持。

List<T> result = jdbcTemplate.query(sql.toString(), new Object[] {queryPara}, new BeanPropertyRowMapper<T>(T.class)) 可以用这个
写方法时没有注意写成了List<T> result = jdbcTemplate.query(sql.toString(), new Object[] {queryPara}, new BeanPropertyRowMapper<ProviderInfo.class>())
执行结果报错java.lang.IllegalStateException: Mapped class was not specified
修改为new BeanPropertyRowMapper<>(ProviderInfo.class);即可

参考文档:
https://blog.csdn.net/will_awoke/article/details/12617383
https://blog.csdn.net/qq_18685059/article/details/84901954

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值