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

在使用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的方法了

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

spring-boot-starter-jdbcSpring Boot框架中的一个starter,它提供了与JDBC(Java Database Connectivity)相关的依赖和配置,使得在Spring Boot应用中使用JDBC变得更加简单和方便。 具体来说,spring-boot-starter-jdbc包含了以下功能: 1. 自动配置:它会根据classpath中的依赖自动配置DataSource(数据源)和JdbcTemplateJDBC模板)等相关的bean。 2. 数据源配置:它提供了默认的数据源配置,可以通过在application.properties或application.yml文件中进行配置,例如指定数据库的URL、用户名、密码等。 3. JdbcTemplate支持:它提供了JdbcTemplate的自动配置,可以通过注入JdbcTemplate对象来执行SQL语句,简化了与数据库的交互操作。 使用spring-boot-starter-jdbc可以让你更加专注于业务逻辑的开发,而无需过多关注底层的数据库连接和操作细节。 如果你想在Spring Boot项目中使用JDBC,可以按照以下步骤进行配置和使用: 1. 在pom.xml文件中添加spring-boot-starter-jdbc依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> ``` 2. 在application.properties或application.yml文件中配置数据源相关信息,例如: ```properties spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=root spring.datasource.password=123456 ``` 3. 在你的代码中注入JdbcTemplate对象,并使用它执行SQL语句,例如: ```java @Autowired private JdbcTemplate jdbcTemplate; public void queryData() { String sql = "SELECT * FROM users"; List<Map<String, Object>> result = jdbcTemplate.queryForList(sql); // 处理查询结果 } ``` 总结一下,spring-boot-starter-jdbcSpring Boot框架中用于简化JDBC操作的一个starter,它提供了自动配置和默认的数据源配置,使得在Spring Boot应用中使用JDBC变得更加方便和高效。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值