本文已参与【新人创作礼】活动,一起开启掘金创作之路。
目录
一、基本介绍
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;
}
}
\