`

JdbcTemplate与事务管理

 
阅读更多

1、JdbcTemplate操作数据库

Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到JdbcTemplate之中。同时,为了支持对properties文件的支持,spring提供了类似于EL表达式的方式,把dataSource.properties的文件参数引入到参数配置之中,<context:property-placeholder location="classpath:jdbc.properties" />。
 
实例代码如下:
提供数据源的相关配置信息:jdbc.properties
driverClassName=org.gjt.mm.mysql.Driver
url=jdbc\:mysql\://localhost\:3306/stanley?useUnicode\=true&characterEncoding\=UTF-8
username=root
password=123456
initialSize=1
maxActive=500
maxIdle=2
minIdle=1

提供spring的配置文件,将jdbc.properties与JdbcTemplate粘合起来的配置文件:beans.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:context="http://www.springframework.org/schema/context"
 xmlns:aop="http://www.springframework.org/schema/aop"
 xmlns:tx="http://www.springframework.org/schema/tx"
 xsi:schemaLocation="http://www.springframework.org/schema/beans
 http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
 http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
 http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">

 <context:property-placeholder location="classpath:jdbc.properties"/>
 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
 <property name="driverClassName" value="${driverClassName}"/>
 <property name="url" value="${url}"/>
 <property name="username" value="${username}"/>
 <property name="password" value="${password}"/>
 <!-- 连接池启动时的初始值 -->
 <property name="initialSize" value="${initialSize}"/>
 <!-- 连接池的最大值 -->
 <property name="maxActive" value="${maxActive}"/>
 <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 -->
 <property name="maxIdle" value="${maxIdle}"/>
 <!-- 最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->
 <property name="minIdle" value="${minIdle}"/>
 </bean>

 <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
 <property name="dataSource" ref="dataSource"/>
 </bean>

 <aop:config>
 <aop:pointcut id="transactionPointcut" expression="execution(* cn.comp.service..*.*(..))"/>
 <aop:advisor advice-ref="txAdvice" pointcut-ref="transactionPointcut"/>
 </aop:config>
 <tx:advice id="txAdvice" transaction-manager="txManager">
 <tx:attributes>
 <tx:method name="get*" read-only="true" propagation="NOT_SUPPORTED"/>
 <tx:method name="*"/>
 </tx:attributes>
 </tx:advice>

 <bean id="personService" class="cn.comp.service.impl.PersonServiceBean">
 <property name="dataSource" ref="dataSource"/>
 </bean>
</beans>

提供POJO的java类:Person.java
public class Person {
 private Integer id;
 private String name;
 
 public Person(){}
 
 public Person(String name) {
 this.name = name;
 }
 public Integer getId() {
 return id;
 }
 public void setId(Integer id) {
 this.id = id;
 }
 public String getName() {
 return name;
 }
 public void setName(String name) {
 this.name = name;
 }
}

提供对Person的操作接口:PersonService.java
public interface PersonService {
 
 public void save(Person person);
 
 public void update(Person person);
 
 public Person getPerson(Integer personid);
 
 public List<Person> getPersons();
 
 public void delete(Integer personid) throws Exception;
}

提供对接口的实现类:PersonServiceBean.java
public class PersonServiceBean implements PersonService {
 private JdbcTemplate jdbcTemplate;
 
 public void setDataSource(DataSource dataSource) {
 this.jdbcTemplate = new JdbcTemplate(dataSource);
 }
 
 public void delete(Integer personid) throws Exception{
 jdbcTemplate.update("delete from person where id=?"new Object[]{personid},
 new int[]{java.sql.Types.INTEGER});
 }
 
 public Person getPerson(Integer personid) { 
 return (Person)jdbcTemplate.queryForObject("select * from person where id=?"new Object[]{personid},
 new int[]{java.sql.Types.INTEGER}, new PersonRowMapper());
 }

 @SuppressWarnings("unchecked")
 public List<Person> getPersons() {
 return (List<Person>)jdbcTemplate.query("select * from person"new PersonRowMapper());
 }

 public void save(Person person) {
 jdbcTemplate.update("insert into person(name) values(?)"new Object[]{person.getName()},
 new int[]{java.sql.Types.VARCHAR});
 }

 public void update(Person person) {
 jdbcTemplate.update("update person set name=? where id=?"new Object[]{person.getName(), person.getId()},
 new int[]{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});
 }
}

提供在查询对象时,记录的映射回调类:PersonRowMapper.java
public class PersonRowMapper implements RowMapper {

 public Object mapRow(ResultSet rs, int index) throws SQLException {
 Person person = new Person(rs.getString("name"));
 person.setId(rs.getInt("id"));
 return person;
 }
}

【注意】:由于dbcp的jar包对common-pool和commons-collections的jar包有依赖,所有需要把他们一起引入到工程中。【 commons-dbcp-1.2.1.jar, commons-pool-1.2.jar, commons-collections-3.1.jar】, 参考文档《JDBC高级部分》:http://tianya23.blog.51cto.com/1081650/270849

2、JdbcTemplate事务
事务的操作首先要通过配置文件,取得spring的支持,再在java程序中显示的使用@Transactional注解来使用事务操作。

在xml配置文件中增加对事务的支持:
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
 <property name="dataSource" ref="dataSource"/>
 </bean>
 <tx:annotation-driven transaction-manager="txManager"/>
 
 <bean id="personService" class="cn.comp.service.impl.PersonServiceBean">
 <property name="dataSource" ref="dataSource"/>
 </bean>

在java程序中显示的指明是否需要事务,当出现运行期异常Exception或一般的异常Exception是否需要回滚
@Transactional
public class PersonServiceBean implements PersonService {
 private JdbcTemplate jdbcTemplate;
 
 public void setDataSource(DataSource dataSource) {
 this.jdbcTemplate = new JdbcTemplate(dataSource);
 }
 // unchecked ,
 // checked
 @Transactional(noRollbackFor=RuntimeException.class)
 public void delete(Integer personid) throws Exception{
 jdbcTemplate.update("delete from person where id=?"new Object[]{personid},
 new int[]{java.sql.Types.INTEGER});
 throw new RuntimeException("运行期例外");
 }
 @Transactional(propagation=Propagation.NOT_SUPPORTED)
 public Person getPerson(Integer personid) { 
 return (Person)jdbcTemplate.queryForObject("select * from person where id=?"new Object[]{personid},
 new int[]{java.sql.Types.INTEGER}, new PersonRowMapper());
 }

 @Transactional(propagation=Propagation.NOT_SUPPORTED)
 @SuppressWarnings("unchecked")
 public List<Person> getPersons() {
 return (List<Person>)jdbcTemplate.query("select * from person"new PersonRowMapper());
 }

 public void save(Person person) {
 jdbcTemplate.update("insert into person(name) values(?)"new Object[]{person.getName()},
 new int[]{java.sql.Types.VARCHAR});
 }

 public void update(Person person) {
 jdbcTemplate.update("update person set name=? where id=?"new Object[]{person.getName(), person.getId()},
 new int[]{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});
 }
}
在默认情况下,Spring会对RuntimeException异常进行回滚操作,而对Exception异常不进行回滚。可以显示的什么什么样的异常需要回滚,什么样的异常不需要回滚,通过 @Transactional(noRollbackFor=RuntimeException.class)设置要求运行时异常不回滚或者通过RollbackFor=Exception.class来要求需要捕获的异常回滚。

【注意】Spring对数据库的操作提供了强大的功能,比如RowMapper接口封装数据库字段与Java属性的映射、查询返回List的函数等,但是里面还要写一堆SQL语句还是比较烦人的,在这部分建议使用ibatis或hibernate来代替,不知道Spring后期的版本会不会把这个整合到里面。
分享到:
评论

相关推荐

    JdbcTemplate的事务控制.docx

    ### JdbcTemplate 的事务...在实际开发中,推荐使用Spring的声明式事务管理,因为它更加简单易用,并且与业务逻辑的耦合度更低。同时,需要注意的是,在处理异常情况时,一定要确保资源的释放,避免资源泄露的问题。

    Spring4--3.jdbcTemplate事务

    在Spring4中,JdbcTemplate与事务管理的结合主要体现在以下几个方面: - **事务回调**:可以使用TransactionCallback接口,在回调方法中执行数据库操作。Spring会自动在事务内部执行这个回调,确保事务的正确性。 ...

    注入JdbcTemplate启用事务管理.docx

    本文将详细讲解如何通过JdbcTemplate启用事务管理,并探讨事务的传播机制。 首先,我们要引入Spring的JDBC支持以及相应的数据库驱动。在`pom.xml`或`build.gradle`文件中,我们需要添加以下依赖(这里以Maven为例)...

    4.Spring中的JdbcTemplate,Spring中的的事务,

    Spring框架支持两种类型的事务管理:编程式事务管理和声明式事务管理。 - **编程式事务管理**:通过编码的方式来管理事务,适用于需要细粒度控制的情况。 - **声明式事务管理**:通过配置来管理事务,更易于使用且...

    配制Spring事务和JdbcTemplate使用

    配制Spring事务和JdbcTemplate使用 配制Spring事务和JdbcTemplate使用

    chap05.rar 配置关于数据库事务介绍的博文

    jdbcTemplate与事务管理结合使用,可以方便地实现事务控制,尤其是在使用连接池时。 在实际应用中,配置这些库和事务管理,需要在Spring的配置文件中指定数据源、事务管理器等相关设置。例如,使用c3p0时,需要配置...

    spring实现jdbctemplate添加事务支持示例

    如果要实现声明式事务,可以在服务层通过使用@Transactional注解来指定事务管理的规则,或者在XML配置文件中配置事务管理器和事务属性,使事务管理与业务逻辑解耦,提高代码的可读性和可维护性。 以上就是对于给定...

    Spring Boot多数据源(JdbcTemplate)配置与使用

    `JdbcTemplate`提供了事务管理、异常转换等特性,避免了手动处理数据库连接、关闭资源等繁琐工作,提高了代码的可读性和可维护性。 配置多数据源在Spring Boot中主要涉及以下几个步骤: 1. 引入依赖:在`pom.xml`...

    Spring事务管理Demo

    2. **声明式事务管理**:这是Spring最常用的方式,通过在配置文件或者使用`@Transactional`注解来定义事务边界,使得事务管理与业务逻辑分离,降低了代码的耦合度。`@Transactional`注解可以应用于方法级别,表示该...

    图书管理系统( Spring+Spring MVC+JdbcTemplate).rar

    Spring是Java企业级应用开发的核心框架,提供了全面的基础设施支持,包括依赖注入(DI)、面向切面编程(AOP)、事务管理等。在图书管理系统中,Spring作为基础框架,负责整个系统的组件管理和依赖注入,使得各个...

    spring-jdbcTemplate实例工程

    Spring JdbcTemplate支持自动和手动的事务管理。在AOP(面向切面编程)的帮助下,可以在方法级别控制事务的开始、提交和回滚。例如,通过@Transactional注解开启事务,当发生异常时,事务会自动回滚。 五、优势与...

    打印JdbcTemplate执行sql

    4. **事务与回滚**:`JdbcTemplate`还提供了事务管理的能力。当在一个事务中执行多条SQL语句时,如果其中一个失败,所有操作都将回滚,确保数据的一致性。你可以通过`JdbcTemplate`的`execute`方法执行一组SQL操作,...

    SpringJdbcTemplate封装工具类

    SpringJdbcTemplate继承自`JdbcAccessor`,包含了事务管理的支持。它可以自动将数据库操作封装在事务中,当出现异常时,会回滚事务,确保数据的一致性。 6. **异常处理** SpringJdbcTemplate将底层JDBC抛出的异常...

    Spring JDBCTemplate连接池jar包

    开发者只需要提供SQL语句和参数绑定,JDBCTemplate会自动处理事务管理、异常转换以及结果集的映射,大大减少了编写数据库操作代码的工作量。 在Spring JDBCTemplate中,连接池扮演着关键角色。连接池管理数据库连接...

    JdbcTemplate

    JdbcTemplate是Spring JDBC模块的核心组件,它的出现极大地减轻了开发者手动处理JDBC连接、事务管理以及异常处理的工作负担。 **1. 数据源注入与配置** 在使用JdbcTemplate之前,首先需要配置数据源(DataSource)...

    JDBCTemplate相关jar包

    总结来说,这些jar包共同构建了一个强大的Java数据库访问环境,使得开发者可以通过Spring的JDBCTemplate方便、高效地进行数据库操作,同时享受Spring框架带来的诸多便利,如事务管理、依赖注入等。通过使用这些库,...

    Spring JdbcTemplate例子

    首先,JdbcTemplate的核心理念是通过预编译的SQL语句和参数绑定来防止SQL注入攻击,同时提供事务管理的支持。它提供了大量方法来执行各种数据库操作,如查询、更新、插入和删除等。 使用Spring JdbcTemplate的第一...

    jdbcTemplate

    2. **事务管理**:`JdbcTemplate`提供了自动的事务管理功能,可以根据配置决定事务的边界,使得在处理数据库操作时无需手动管理事务。 3. **异常处理**:它将数据库驱动抛出的`SQLException`转换为Spring的`...

    Spring JdbcTemplate&声明式事务1

    在本篇中,我们将深入探讨JdbcTemplate的基本使用和声明式事务管理。 ### JdbcTemplate基本使用 **1. 引入依赖** 首先,我们需要在项目中引入Spring JDBC和Spring事务管理的相关依赖。在Maven项目中,这通常通过...

Global site tag (gtag.js) - Google Analytics