Spring学习5-Spring整合JDBC及其事务处理(注解方式)
一、整合的步骤
1、步骤一:首先要获得DataSource连接池(推荐使用B方式):
要对数据库执行任何的JDBC操作,需要有一个Connection.在Spring中,Connection对象是通过DataSource获得的。
有几种方法可以得到DataSource,
其中一种方法是使用Spring提供的轻量级
org.springframework.jdbc.datasource.DriverManagerDataSource,第二种方法是使用
org.apache.commons.dbcp.BasicDataSource类。
A:使用DriverMangerDataSource获取DataSource,这种方法是轻量级的,方便测试
public class
DataSoureProvider {
public static DriverManagerDataSource dataSource = new
DriverManagerDataSource();
public static DriverManagerDataSource getInstance() {
dataSource.setDriverClassName("com.mysql.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://localhost:3306/book");
dataSource.setUsername("y****");
dataSource.setPassword("h*******");
return dataSource;
}
@Test
public void test() {
DataSoureProvider.getInstance();
try {
dataSource.getConnection();
}
catch (SQLException e) {
e.printStackTrace();
}
}
}
B:通过使用BasicDataSouce创建一个连接池获取DataSource。应为BasicDataSource所有属性都是通过setter方法暴露在外面的,我们可以像配置其他Srping
Bean那样配置它我将数据库连接信息配置在properties文件中,利用spring的org.springframeword.beans.factory.config.PropertyPlaceholderConfigurer类进行读取装载。
注意:
使用org.apache.commons.dbcp.BasicDataSource需要引入额外的jar包,分别是,commons-dbcp-1.4.jar,commons-pool-1.2.jar
(官网下载页面:http://commons.apache.org/)
书写配置文件applicationContext.xml:
<?xml
version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<bean id="dbproperty"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property
name="location">
<!-- 此位置是相对于:部署后的项目的根路径
<value>/WEB-INF/connect.properties</value>
-->
<!-- 此位置是相对于:部署后的项目的类路径
-->
<value>connect.properties</value>
</property>
</bean>
<-- 配置BasicDataSource参数,其中<value>中的参数是在connect.propertices配置文件
中拿到的,其实value值也可以直接写上的-->
<bean id="myDataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property
name="driverClassName">
<value>${db.driver}</value>
</property>
<property name="url">
<value>${db.url}</value>
</property>
<property name="username">
<value>${db.username}</value>
</property>
<property name="password">
<value>${db.password}</value>
</property>
</bean>
</beans>
--------------------------------------------------------------------------------------
2、步骤二:使用JdbcTemplate类操作数据库:
Spring把JDBC中重复的操作建立成了一个模板类:org.springframework.jdbc.core.JdbcTemplate。
A:要使用JdbcTemplate,需要为每一个DAO配置一个JdbcTemplate实例:
public class StudentDaoImp implements StudentDao
{
private JdbcTemplate jdbcTemplate;
@Override
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
}
B:如上,StudentDaoImp内配置了一个JdbcTemplate对象和它对应的setter方法。这样就可以在Spring配置文件中对其进行赋值。
<?xml version="1.0"
encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">
<bean id="dbproperty"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="location">
<value>connect.properties</value>
</property>
</bean>
<bean id="myDataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property
name="driverClassName">
<value>${db.driver}</value>
</property>
<property name="url">
<value>${db.url}</value>
</property>
<property name="username">
<value>${db.username}</value>
</property>
<property name="password">
<value>${db.password}</value>
</property>
</bean>
<bean id="jdbcTemplate"
class="org.springframework.jdbc.core.JdbcTemplate">
<constructor-arg
ref="myDataSource"></constructor-arg>
</bean>
<bean id="studentDao"
class="com.sunflower.dao.StudentDaoImp">
<property name="jdbcTemplate">
<ref bean="jdbcTemplate"/>
</property>
</bean>
</beans>
C:使用JdbcTemplate插入数据:
1)插入单条数据:JdbcTemplate为我们提供了update(String sql,Object...
args)方法,方便我们进行数据的插入.
2)批量添加数据:批量插入数据需要用到org.springframework.jdbc.core.BatchPreparedStatementSetter接口。BatchPreparedStatementSetter接口的两个方法,其中getBatchSize()方法是得到需要插入的记录的个数,setValues(PreparedStatement
ps, int index)方法是实际进行插入的方法。
3)查询单条记录:执行一条数据的查询,需要使用org.springframework.jdbc.core.RowCallbackHandler接口的实现。
4)查询多条记录:这里需要用到org.springframework.jdbc.core.RowMapper接口的实现。RowMapper接口负责把Result中的一条记录映射成一个对象。
public class StudentDaoImp implements
StudentDao {
private JdbcTemplate jdbcTemplate;
@Override
public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
this.jdbcTemplate = jdbcTemplate;
}
//插入单条数据
public void insert(Student student)
{
String sql = "insert into student (cno,name,score)
values(?,?,?)";
//设置传递给通配符的参数
Object[] params = new Object[]{student.getCno(), student.getName(),
student.getScore()};
jdbcTemplate.update(sql, params);
}
//批量插入数据
public int[]
batchInsert(final List<Student>
list)
{
String sql = "insert into student (cno,name,score)
values(?,?,?)";
BatchPreparedStatementSetter setter = new
BatchPreparedStatementSetter() {
@Override
public void setValues(PreparedStatement ps, int index) throws
SQLException {
Student student = (Student) list.get(index);
ps.setInt(1, student.getCno());
ps.setString(2, student.getName());
ps.setDouble(3, student.getScore());
}
//有多少条记录要处理
@Override
public int getBatchSize() {
return list.size();
}
};
return jdbcTemplate.batchUpdate(sql, setter);
}
//查询单条记录
public Student getStudent(final int id) {
// 装载查询结果
final Student student = new Student();
String sql = "select s.cno,s.name,s.score from student s where sno
= ?";
// 设置查询参数
final Object[] params = new Object[] { new Integer(id) };
// 进行查询
jdbcTemplate.query(sql, params,
new RowCallbackHandler() {
@Override
public void processRow(ResultSet rs) throws SQLException {
student.setCno(rs.getInt("cno"));
student.setName(rs.getString("name"));
student.setScore(rs.getDouble("score"));
}
});
return student;
}
//查询多条记录
public List<Student> getAllStudent()
{
String sql = "select s.cno,s.name,s.score from student s";
return jdbcTemplate.query(sql,
new
RowMapper<Student>() {
@Override
public Student mapRow(ResultSet rs, int index) throws SQLException
{
Student student = new Student();
student.setCno(rs.getInt("cno"));
student.setName(rs.getString("name"));
student.setScore(rs.getDouble("score"));
return student;
}
});
}
}
另附:也可以使用org.springframework.jdbc.core.RowMapper接口查询一条记录,只要附加查询参数即可:
public Student getStudent(final int id) {
// 装载查询结果
final Student student = new Student();
String sql = "select s.cno,s.name,s.score from student s where sno
= ?";
// 设置查询参数
final Object[] params = new Object[] { new Integer(id) };
List<Student> list = jdbcTemplate.query(sql, params,
new
RowMapper<Student>() {
@Override
public Student mapRow(ResultSet rs, int index)
throws SQLException {
Student student = new Student();
student.setCno(rs.getInt("cno"));
student.setName(rs.getString("name"));
student.setScore(rs.getDouble("score"));
return student;
}
});
return list.get(0);
}
二、采用注解方式配置事务处理
1、在Spring配置文件beans元素中添加子元素:
<!– 声明事务管理器
-->
<bean
id="txManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource"
ref="dataSource"/>
</bean>
<!–
采用@Transactional注解方式使用事务 -->
<tx:annotation-driven
transaction-manager="txManager"/>
2、在业务逻辑的试下类中使用注解添加相应的事务
@Service @Transactional
public class StudentServiceBean implements StudentService {
@Transactional(类型=值)
public void add(Student stu) {
dao.insert(stu);
}
}
Spring学习5-Spring整合JDBC及其事务处理(注解方式)的更多相关文章
- 【Spring学习笔记-MVC-4】SpringMVC返回Json数据-方式2
<Spring学习笔记-MVC>系列文章,讲解返回json数据的文章共有3篇,分别为: [Spring学习笔记-MVC-3]SpringMVC返回Json数据-方式1:http://www ...
- 【Spring学习笔记-MVC-3】SpringMVC返回Json数据-方式1
<Spring学习笔记-MVC>系列文章,讲解返回json数据的文章共有3篇,分别为: [Spring学习笔记-MVC-3]SpringMVC返回Json数据-方式1:http://www ...
- Spring学习(十一)-----Spring使用@Required注解依赖检查
Spring学习(九)-----Spring依赖检查 bean 配置文件用于确定的特定类型(基本,集合或对象)的所有属性被设置.在大多数情况下,你只需要确保特定属性已经设置但不是所有属性.. 对于这种 ...
- Spring学习(六)-----Spring使用@Autowired注解自动装配
Spring使用@Autowired注解自动装配 在上一篇 Spring学习(三)-----Spring自动装配Beans示例中,它会匹配当前Spring容器任何bean的属性自动装配.在大多数情况下 ...
- (转)Spring使用AspectJ进行AOP的开发:注解方式
http://blog.csdn.net/yerenyuan_pku/article/details/69790950 Spring使用AspectJ进行AOP的开发:注解方式 之前我已讲过Sprin ...
- Spring整合JDBC及事务处理
1.Spring整合JDBC DAO是数据访问对象(data access object)的简写.接口是实现松耦合的关键,Spring也鼓励使用接口,但不是强制的. 捕获异常时希望能尝试从异常状态中恢 ...
- spring学习 六 spring与mybatis整合
在mybatis学习中有两种配置文件 :全局配置文件,映射配置文件.mybatis和spring整合,其实就是把mybatis中的全局配置文件的配置内容都变成一个spring容器的一个bean,让sp ...
- Spring学习之Spring与Mybatis的两种整合方式
本机使用IDEA 2020.1.MySql 8.0.19,通过Maven进行构建 环境准备 导入maven依赖包 <dependencies> <dependency> < ...
- spring学习07(整合MyBatis)
10.整合MyBatis 10.1 相关jar包 junit <dependency> <groupId>junit</groupId> <artifactI ...
随机推荐
- py变量
1, python以数据为主 x=2,是给数据2开辟了个空间, X指向了2 y=x ,即y指向了2 x=5 ,x重新赋值 但是y依旧是原来的
- [应用层]mail邮件协议
转:http://***/chapter-14/ 以前老记不住这smtp和pop3谁收谁发. 简单邮件传输协议(SMTP),用来发送或中转发出的电子邮件,占用tcp 25端口. 第三版邮局协议(POP ...
- php基础04:字符串函数
<?php //1.strlen(),strlen() 函数返回字符串的长度,以字符计. echo strlen("hello world"); echo "< ...
- 学习Shell脚本编程(第5期)_表达式的比较
字符串操作符 逻辑运算符 用test比较的运算符 数字比较符 文件操作符 在Shell程序中,通常使用表达式比较来完成逻辑任务.表达式所代表的操作符有字符操作符.数字操作符.逻辑操作符.以及文件操作符 ...
- eclipse系列: Cannot change version of project facet Dynamic web的解决方法
问题描述 用Eclipse创建Maven结构的web项目的时候选择了Artifact Id为maven-artchetype-webapp,由于这个catalog比较老,用的servl ...
- pythonchallenge(三)
PythonChallenge_3 一.实验说明 1. 环境登录 无需密码自动登录,系统用户名shiyanlou,密码shiyanlou 2. 环境介绍 本实验环境采用带桌面的Ubuntu Linux ...
- CDC类
CDC :class of device context Windows使用与设备无关的图形设备环境(DC :Device Context) 进行显示 .MFC基础类库定义了设备环境对象类----CD ...
- 什么是co-training
首先先认识下什么是co-training: 在计算机视觉中,我们都知道训练一个分类器的时候,我们需要两类样本,分别是正样本和负样本.监督训练又可以成为off-line training,就是提前准备好 ...
- HoloLens开发手记 - Unity之Spatial mapping 空间映射
本文主要讨论如何在Unity项目中集成空间映射功能.Unity内置了对空间映射功能的支持,通过以下两种方式提供给开发者: HoloToolkit项目中你可以找到空间映射组件,这可以让你便捷快速地开始使 ...
- Android响应式界面开发要点
现在很多项目需要到达同一个Apk既可以在Phone上跑也尅在tablet上跑,即界面要适应不同尺寸和类型的需要而自动调整.这个即为响应式设计.在web开发商响应式设计已经是个常谈的内容了,而对于and ...