传统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);
}

玩转Spring——Spring整合JDBC的更多相关文章

  1. Spring Boot 整合JDBC 实现后端项目开发

    一.前言 二.新建Spring Boot 项目 三.Spring Boot 整合JDBC 与MySQL 交互 3.1 新建数据表skr_user 3.2 Jdbcproject 项目结构如下 3.3 ...

  2. 【Spring Boot学习之三】Spring Boot整合数据源

    环境 eclipse 4.7 jdk 1.8 Spring Boot 1.5.2 一.Spring Boot整合Spring JDBC 1.pom.xml <project xmlns=&quo ...

  3. JAVAEE——spring03:spring整合JDBC和aop事务

    一.spring整合JDBC 1.spring提供了很多模板整合Dao技术 2.spring中提供了一个可以操作数据库的对象.对象封装了jdbc技术. JDBCTemplate => JDBC模 ...

  4. Spring整合JDBC以及AOP管理事务

    本节内容: Spring整合JDBC Spring中的AOP管理事务 一.Spring整合JDBC Spring框架永远是一个容器,Spring整合JDBC其实就是Spring提供了一个对象,这个对象 ...

  5. Spring整合jdbc

    首先web.xml文件跟往常一样,加载spring容器和加载org.springframework.web.context.ContextLoaderListener读取applicationCont ...

  6. Spring整合JDBC及事务处理

    1.Spring整合JDBC DAO是数据访问对象(data access object)的简写.接口是实现松耦合的关键,Spring也鼓励使用接口,但不是强制的. 捕获异常时希望能尝试从异常状态中恢 ...

  7. Spring整合JDBC实现简单的增删改

    Spring整合JDBC实现简单的增删改: 1.导入Spring的包和数据库的驱动包: 2.选择一个数据源(dbcp和C3P0) 3.导入数据源的包(这里我们使用dbcp) <span styl ...

  8. Spring知识点总结(五)Spring整合JDBC

     1. 回顾JDBC        a. java操作关系型数据的API.导入相关数据库的驱动包后可以通过JDBC提供的接口来操作数据库.        b. 实现JDBC的六个步骤          ...

  9. Spring整合JDBC和Druid连接池

    我的博客名为黑客之谜,喜欢我的,或者喜欢未来的大神,点一波关注吧!顺便说一下,双十二快到了,祝大家双十二快乐,尽情的买买买~ 如果转载我的文章请标明出处和著名,谢谢配合. 我的博客地址为: https ...

  10. Spring整合JDBC(连接池、JDBC模板、Dao配置到Spring容器、配置文件的优化)

    1.Spring整合JDBC (1)导包(共12个): c3p0连接池.JDBC驱动(4个) Spring-jdbc.Spring-tx事务(2个) (2)JDBC模板对象(JDBCTemplate) ...

随机推荐

  1. Laravel 配置 SqlDebug 服务,进行实时监听打印 SQL

    0:释义 什么是服务容器 简而言之,Laravel 服务容器 是一个用于存储绑定组件的盒子,它还会为应用提供所需的服务. Laravel 服务容器是用于管理类的依赖和执行依赖注入的工具,By Lara ...

  2. Day02_企业权限管理(SSM整合)

    学于黑马程序员和传智播客联合做的教学项目 感谢 黑马程序员官网 传智播客官网 个人根据教程的每天的工作进度的代码和资料 密码:cti5 b站在线视频 微信搜索"艺术行者",关注并回 ...

  3. CF 633 div1 1338 B. Edge Weight Assignment 构造

    LINK:Edge Weight Assignment 这场当时没打 看到这个B题吓到我了 还好当时没打. 想了20min才知道怎么做 而且还不能证明. 首先考虑求最小. 可以发现 如果任意两个叶子节 ...

  4. 【Canal】互联网背景下有哪些数据同步需求和解决方案?看完我知道了!!

    写在前面 在当今互联网行业,尤其是现在分布式.微服务开发环境下,为了提高搜索效率,以及搜索的精准度,会大量使用Redis.Memcached等NoSQL数据库,也会使用大量的Solr.Elastics ...

  5. SpringBoot一个依赖搞定session共享

    原文:微信公众号:Java开发宝典  https://mp.weixin.qq.com/s/_VFY9lXqNhH8Nh4HC9tuMg 1. 前言 在传统的单服务架构中,一般来说,只有一个服务器,那 ...

  6. Jenkins总结3-shell脚本

    我写shell脚本的功力还很初级,基本都是现学现卖,写得不是很健壮,只能提供个思路,请大家包涵. 我使用的系统只能发函数放到shell最前面.本人还是比较推崇函数式脚本的,方便复用,目前只简单的封装了 ...

  7. 移动物体监控系统-sprint2摄像头子系统开发

    一.摄像头使能驱动 1.1 摄像头软件系统构架 摄像头采集系统按照上图,硬件(摄像头)->摄像头驱动 ->V4L2接口规范 ->图像采集(应用).V4L2将不同类型的摄像头设备按照统 ...

  8. 最新版 源码编译 docker

    前言: 最近想研究 docker 源码,那么要研究源码第一步就是学会通过源码编译.然后在网上查找了很多,都是比较老的版本.目前官最新的版本是 18.09.经过一番探索之后,终于成功编译了 下面我把我的 ...

  9. “随手记”开发记录day16

    今天先对前两天增加的“修改”功能进行测试.然后进行功能的明显划分,丰富账单的添加和显示方法.

  10. 手把手教你使用Python网络爬虫获取招聘信息

    1.前言 现在在疫情阶段,想找一份不错的工作变得更为困难,很多人会选择去网上看招聘信息.可是招聘信息有一些是错综复杂的.而且不能把全部的信息全部罗列出来,以外卖的58招聘网站来看,资料整理的不清晰. ...