JdbcTemplate_声明式事务控制

JdbcTemplete

jdbc是Spring提供的专门操作关系型数据库的模板,由于操作数据库是有事务控制的,所以需要导入jdbc和tx的pom包;

xml配置

<!--数据源对象-->
  <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
    <property name="driverClass" value="com.mysql.jdbc.Driver"></property>
    <property name="jdbcUrl" value="jdbc:mysql:///test"></property>
    <property name="user" value="root"></property>
    <property name="password" value="root"></property>
  </bean>
  <!--jdbc模板对象-->
  <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
    <property name="dataSource" ref="dataSource"/>
  </bean>

常用方法:

jdbcTemplate.update (sql,params)

jdbcTemplate.queryForObject(sql,Mapper,params)

jdbcTemplate.query (sql,Mapper,params)

声明式事务

声明式事务:通过xml或者注解的方式,声明配置;

编程式事务:需要手动编写事务代码控制事务;

PlatformTransactionManager接口

spring提供的事务管理器接口,提供了我们常用的操作事务的方法;一般由子类实现了;

DataSourceTransactionManager:Jdbc和mybatis作为dao层时选择的子类实现;

HibernateTransactionManager:hibernate作为dao层时选择的子类实现;

TransactionDefinition 是事务的定义信息对象

1. 事务隔离级别

设置隔离级别,可以解决事务并发产生的问题,如脏读、不可重复读和虚读。

ISOLATION_DEFAULT
ISOLATION_READ_UNCOMMITTED
ISOLATION_READ_COMMITTED
ISOLATION_REPEATABLE_READ
ISOLATION_SERIALIZABLE

2. 事务传播行为

REQUIRED:如果当前没有事务,就新建一个事务,如果已经存在一个事务中,加入到这个事务中。一般的
选择(默认值)
SUPPORTS:支持当前事务,如果当前没有事务,就以非事务方式执行(没有事务)

MANDATORY:使用当前的事务,如果当前没有事务,就抛出异常
REQUERS_NEW:新建事务,如果当前在事务中,把当前事务挂起。
NOT_SUPPORTED:以非事务方式执行操作,如果当前存在事务,就把当前事务挂起
NEVER:以非事务方式运行,如果当前存在事务,抛出异常
NESTED:如果当前存在事务,则在嵌套事务内执行。如果当前没有事务,则执行 REQUIRED 类似的操作
超时时间:默认值是-1,没有超时限制。如果有,以秒为单位进行设置
是否只读:建议查询时设置为只读

TransactionStatus 接口提供的是事务具体的运行状态

XML 的声明式事务控制

<!--平台事务管理器-->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  <property name="dataSource" ref="dataSource"></property>
</bean>
<!--事务增强配置-->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
  <tx:attributes>
    <tx:method name="transfer" isolation="REPEATABLE_READ" propagation="REQUIRED" 
        timeout="-1" read-only="false"/>
    <tx:method name="*"/>
  </tx:attributes>
</tx:advice>
<!--事务的aop增强-->
<aop:config>
  <aop:pointcut id="myPointcut" expression="execution(* com.itheima.service.impl.*.*
(..))"/>
  <aop:advisor advice-ref="txAdvice" pointcut-ref="myPointcut"></aop:advisor>
</aop:config>

注解的声明式事务控制

需要手动配置平台事务管理器和tx事务注解

@Service("accountService")
@Transactional
public class AccountServiceImpl implements AccountService {
  @Autowired
  private AccountDao accountDao;
  @Transactional(isolation = Isolation.READ_COMMITTED,propagation =
Propagation.REQUIRED)
  public void transfer(String outMan, String inMan, double money) {
    accountDao.out(outMan,money);
    int i = 1/0;
    accountDao.in(inMan,money);
 }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Spring 中,我们可以通过编程式事务和声明式事务来处理数据库事务。下面我来分别介绍一下这两种事务的实现。 ## 编程式事务 编程式事务是通过代码实现事务控制,需要手动创建和提交事务。Spring 提供了一个名为 `TransactionTemplate` 的类来帮助我们实现编程式事务。 我们可以使用 `TransactionTemplate` 来控制事务的开启、提交、回滚等操作。下面是一个简单的例子: ```java @Service public class UserService { @Autowired private JdbcTemplate jdbcTemplate; @Autowired private TransactionTemplate transactionTemplate; public void transfer(int fromId, int toId, int amount) { transactionTemplate.execute(new TransactionCallbackWithoutResult() { @Override protected void doInTransactionWithoutResult(TransactionStatus status) { try { jdbcTemplate.update("update account set amount = amount - ? where id = ?", amount, fromId); jdbcTemplate.update("update account set amount = amount + ? where id = ?", amount, toId); } catch (Exception e) { status.setRollbackOnly(); throw e; } } }); } } ``` 上面的代码中,我们使用 `TransactionTemplate` 来控制转账操作的事务,如果出现异常,则会回滚事务。 ## 声明式事务 声明式事务是通过配置文件来实现事务控制,无需手动创建和提交事务。Spring 提供了一个叫做 `@Transactional` 的注解来帮助我们实现声明式事务。 我们只需要在需要添加事务的方法上加上 `@Transactional` 注解,就可以实现声明式事务。下面是一个简单的例子: ```java @Service public class UserService { @Autowired private JdbcTemplate jdbcTemplate; @Transactional public void transfer(int fromId, int toId, int amount) { jdbcTemplate.update("update account set amount = amount - ? where id = ?", amount, fromId); jdbcTemplate.update("update account set amount = amount + ? where id = ?", amount, toId); } } ``` 上面的代码中,我们在 `transfer` 方法上添加了 `@Transactional` 注解,这样就可以实现转账操作的事务控制了。 声明式事务的好处是我们无需手动创建和提交事务,代码更加简洁,但是配置稍微复杂一些。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值