Spring 事务操作

74 阅读3分钟

​本文已参与【新人创作礼】活动,一起开启掘金创作之路。

目录

一、基本介绍

二、事务操作(注解声明式事务管理)

1 、在 spring 配置文件配置事务管理器

2、在 spring  配置文件,开启事务注解

3、事务操作(声明式事务管理参数配置)

4.使用配置类替代 xml 


一、基本介绍

1 、事务添加到 JavaEE 三层结构里面 Service 层(业务逻辑层)

2 、在 Spring 进行事务管理操作有两种方式:编程式事务管理和声明式事务管理(使用)

3 、声明式事务管理

  • 基于注解方式 (使用)
  • 基于 xml 配置文件方式

4 、在 Spring  进行声明式事务管理,底层使用 AOP 原理

5 、Spring 事务管理 API
提供一个接口,代表事务管理器,这个接口针对不同的框架提供不同的实现类 

​编辑

二、事务操作(注解声明式事务管理)

1 、在 spring 配置文件配置事务管理器

<!--配置连接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/testrewriteBatchedStatements=true"/>
        <property name="username" value="root"/>
        <property name="password" value="12345/>
</bean>

<!--创建事务管理器-->
<bean id="transactionManager"class= "org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <!--注入数据源-->
    <property name="dataSource" ref="dataSource"></property>
</bean>

2、在 spring  配置文件,开启事务注解

(1)在 spring 配置文件引入名称空间 tx

​编辑

(2)开启事务注解

<!--开启事务注解-->
<tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven> 

(3)在 service 类上面或者 (service类里面方法上)添加事务注解

@Transactional,这个注解添加到类上面,也可以添加方法上面,如果把这个注解添加类上面,这个类里面所有的方法都添加事务,如果把这个注解添加方法上面,为这个方法添加事务。

@Service
@Transactional
public class UserService {
}

3、事务操作(声明式事务管理参数配置)

在 service 类上面添加注解@Transactional,在这个注解里面可以配置事务相关参数

​编辑

1、propagation :事务传播行为

​编辑

​编辑

2、ioslation:事务隔离级别

1)有三个读问题:脏读、不可重复读、虚(幻)读

脏读:一个未提交事务读取到另一个未提交事务的数据

​编辑

不可重复读:一个未提交事务读取到另一提交事务修改数据​编辑

虚读:一个未提交事务读取到另一提交事务添加数据

2)解决:通过设置事务隔离级别,解决读问题

​编辑

3 、timeout :超时时间
事务需要在一定时间内进行提交,如果不提交进行回滚,默认值是 -1 ,设置时间以秒单位进行计算


4、readOnly :是否只读
(1)读:查询操作,写:添加修改删除操作
(2)readOnly 默认值 false,表示可以查询,可以添加修改删除操作
(3)设置 readOnly 值是 true,设置成 true 之后,只能查询


5、rollbackFor :回滚
设置出现哪些异常进行事务回滚


6、noRollbackFor :不回滚
设置出现哪些异常不进行事务回滚

4.使用配置类替代 xml 

@Configuration
@ComponentScan(basePackages = {"dao","service"})
@EnableTransactionManagement //开启事务
public class TxConfig {
    //创建数据库连接池
    @Bean
    public DruidDataSource getDruidDataSource() {
        DruidDataSource dataSource = new DruidDataSource();
        dataSource.setDriverClassName("com.mysql.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/test?rewriteBatchedStatements=true");
        dataSource.setUsername("root");
        dataSource.setPassword("12345");
        return dataSource;
    }

    //创建事务管理器
    @Bean
    public DataSourceTransactionManager getDataSourceTransactionManager(DataSource dataSource) {
        DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
        transactionManager.setDataSource(dataSource);
        return transactionManager;
    }
}

\