使用spring中的JdbcTemplate来完成对数据库的查询(返回一个对象)操作,抛出异常

出现的错误为:

Exception in thread "main" org.springframework.beans.BeanInstantiationException: Failed to instantiate [entity.User]: Is it an abstract class?; nested exception is java.lang.InstantiationException: entity.User
    at org.springframework.beans.BeanUtils.instantiate(BeanUtils.java:106)
    at org.springframework.jdbc.core.BeanPropertyRowMapper.mapRow(BeanPropertyRowMapper.java:236)
    at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:93)
    at org.springframework.jdbc.core.RowMapperResultSetExtractor.extractData(RowMapperResultSetExtractor.java:60)
    at org.springframework.jdbc.core.JdbcTemplate$1.doInPreparedStatement(JdbcTemplate.java:708)
    at org.springframework.jdbc.core.JdbcTemplate.execute(JdbcTemplate.java:644)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:695)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:727)
    at org.springframework.jdbc.core.JdbcTemplate.query(JdbcTemplate.java:737)
    at org.springframework.jdbc.core.JdbcTemplate.queryForObject(JdbcTemplate.java:811)
    at dao.DaoImpl.findUser(DaoImpl.java:63)
    at service.Service.findUser(Service.java:27)
    at test.main(test.java:21)
Caused by: java.lang.InstantiationException: entity.User
    at java.lang.Class.newInstance(Class.java:427)
    at org.springframework.beans.BeanUtils.instantiate(BeanUtils.java:103)
    ... 12 more
Caused by: java.lang.NoSuchMethodException: entity.User.<init>()
    at java.lang.Class.getConstructor0(Class.java:3082)
    at java.lang.Class.newInstance(Class.java:412)
    ... 13 more

        抛出异常是由于实体类的构造函数造成的。

        解决办法是:

①要么不设置构造函数。

②要么设置满参构造函数和空参函构造数。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值