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