玩转Spring——Spring整合JDBC

传统JDBC代码的弊端
在传统的jdbc代码中,即使是执行一条简单的SQL语句,其实现的整个流程也是极为繁琐的,先打开数据库连接执行sql,然后组装结果,最后关闭数据库资源,这中间还有大量的try...catch...finally语句,造成了代码的泛滥,导致我们的代码可读性和可维护性急剧下降,从而引发信任问题,为了解决这些“疑难杂症”。Spring提供了自己的解决方案,那就是JdbcTemplate模板。

实现步骤:

1.以c3p0连接mysql为例,使用c3p0需要导入两个相关jar包:
c3p0-0.9.1.2.jar
以及数据库jar: mysql-connector-java-5.1.7-bin.jar
以及事物相关jar:spring-tx-4.2.4.RELEASE.jar spring-jdbc-4.2.4.RELEASE.jar

2、书写资源文件jdbc.properties

<!-- 注意这里有坑,者四个键值对的键要么固定这么写,要么就以jdbc.***的方式,切记用以下方式写,却把user写成username,这是因为spring加载时username这个键被其他地方使用了 -->
url=jdbc:mysql://localhost:3306/test?characterEncoding=utf-8
user=root
password=123456
driver=com.mysql.jdbc.Driver

3.书写配置文件

<context:property-placeholder
location="classpath:jdbc.properties" />
<bean id="dataSource"
class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="driverClass" value="${driver}"></property>
<property name="jdbcUrl" value="${url}"></property>
<property name="user" value="${user}"></property>
<property name="password" value="${password}"></property>
<!-- 这里还可以配置其他参数,比如initialPoolSize等等 -->
</bean>
<bean class="org.springframework.jdbc.core.JdbcTemplate">
<property name="dataSource" ref="dataSource"></property>
</bean>
<context:component-scan base-package="com.eric.jdbc"></context:component-scan>
</beans>

4.创建实体类:

//创建一个实体类,很简单,这里省略
public class BankUser {……}

5.创建一个实体类的映射类(用于指定数据库到实体类的字段映射关系):
通过RowMapper接口的实现,将每行数据映射到实例对象。但不必担心异常处理。调用JdbcTemplate将捕获并处理SQLExceptions。

public class BankUserMapper implements RowMapper<BankUser> {
public BankUser mapRow(ResultSet resultSet, int i) throws SQLException {
BankUser bankUser=new BankUser();
bankUser.setId(resultSet.getString("id"));
bankUser.setUserName(resultSet.getString("user_name"));
bankUser.setPassword(resultSet.getString("password"));
return bankUser;
}
}


6.书写DAO:

@Repository
public
class UserDAOImpl { @Autowired private JdbcTemplate template;//必须注入JdbcTemplate模板 // 查询单个数据: public BankUser findUserByname(String userName){ //在JdbcTemplate 都是使用?作为占位符 String sql ="select * from bank where id=?"; Object[] params = {userName}; RowMapper<BankUser> mapper = new BankUserMapper(); BankUser bankUser=template.queryForObject(sql, params,mapper); return bankUser; } } //查询多个数据: public List<BankUser> findAllUser(){ String sql ="select * from bank"; RowMapper<BankUser> mapper = new BankUserMapper(); List<BankUser> list=template.query(sql,mapper); return list; } //插入一条数据: public void save(BankUser bankUser) { String sql = "insert into bank(id,user_name,password,money) values (?,?,?,?)"; Object[] params = { bankUser.getId(),bankUser.getPassword(), bankUser.getUserName(), bankUser.getMoney() }; template.update(sql, params); } //修改数据: public void update(BankUser bankUser){ String sql = "update bank set password=? where id=?"; Object[] params ={bankUser.getPassword(),bankUser.getId()}; template.update(sql, params); } //删除数据: public void deleteUser(String id){ String sql = "delete from emp where id=?"; Object[] params = {id}; template.update(sql, params); }
原文地址:https://www.cnblogs.com/ericz2j/p/10908990.html