找不到符号:SimpleJdbcTemplate

在将Spring JDBC从3.1升级到4.3时,遇到SimpleJdbcTemplate找不到类的问题。该问题源于SimpleJdbcTemplate在Spring 4.3中已被完全移除。解决方案是使用JdbcTemplate和NamedParameterJdbcTemplate作为替代,并通过grep和sed命令进行全局代码替换。

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

找不到类SimpleJdbcTemplate


背景

想编译个web应用,原来spring-jdbc.jar用的是Spring 3.1,今天改成用Spring 4.3,报了这个错误。


现象

编译不通过,报错如下:

Error:(19, 44) java: 找不到符号
  符号:   类 SimpleJdbcTemplate
  位置: 程序包 org.springframework.jdbc.core.simple
Error:(17, 44) java: 找不到符号
  符号:   类 ParameterizedRowMapper
  位置: 程序包 org.springframework.jdbc.core.simple

原因

从Spring 3.1开始,JdbcTemplateNamedParameterJdbcTemplate提供了SimpleJdbcTemplate的功能。
SimpleJdbcTemplateSimpleJdbcDaoSupport被标记为过时,到Spring 4.3则被完全移除

注:org.springframework.jdbc.core.simple.ParameterizedRowMapper也已经被移除
至于是在哪个版本的时候被移除就不清楚了。


解决办法

思路


  • org.springframework.jdbc.core.RowMapper
    代替
    org.springframework.jdbc.core.simple.ParameterizedRowMapper.

  • org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate
    代替
    org.springframework.jdbc.core.simple.SimpleJdbcTemplate.
    值得注意的是:
    NamedParameterJdbcTemplate是基于JdbcTemplate实现的,小部分接口和SimpleJdbcTemplate不同

类图

具体办法

问题来了,当有分散在多地的代码都使用了SimpleJdbcTemplate,如何快速地替换为NamedParameterJdbcTemplate
如果你对IDE非常熟悉,或许能很快全局替换,然而本人智商比较爪机,使用sed命令更合适点。

  • *RowMapper*替换*ParameterizedRowMapper*
sudo sed -i 's/org.springframework.jdbc.core.simple.ParameterizedRowMapper/org.springframework.jdbc.core.RowMapper/g' `grep -rl 'org.springframework.jdbc.core.simple.ParameterizedRowMapper'`
  • NamedParameterJdbcTemplate替换SimpleJdbcTemplate
sudo sed -i 's/org.springframework.jdbc.core.simple.SimpleJdbcTemplate/org.springframework.jdbc.core.namedparam.NamedParameterJdbcTemplate/g' `grep -rl 'org.springframework.jdbc.core.simple.SimpleJdbcTemplate'`

说明

grep是查找命令,选项r表示级联查找,选项l表示输出包含目标的文件(不加l是输出匹配到的行)。
sed是编辑命令,选项i表示将更改写入文件(不加的话是只将更改输出到console)。

s/org.springframework.jdbc.core.simple.ParameterizedRowMapper/org.springframework.jdbc.core.RowMapper/g

↑是全局替换的意思。
另外,注意区别反引号和单引号哦。


参考

sed命令参考:http://www.iteye.com/topic/587673

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值