Spring中怎么配置事务管理
导读:本文共1555.5字符,通常情况下阅读需要5分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 在springboot中,使用事务非常的简单,因为springboot已经帮我们配置好了,只需要加上注解@Transactional即可在spring中我们需要做一些配置:主要有三点:@Transactional:在相应的方法上加上这个注解 @EnableTransactionManagement:在配置类中加上,开启事务管理 需要在配置类中加入Platform... ...
目录
(为您整理了一些要点),点击可以直达。在springboot中,使用事务非常的简单,因为springboot已经帮我们配置好了,只需要加上注解@Transactional即可
在spring中我们需要做一些配置:主要有三点:
@Transactional:在相应的方法上加上这个注解 @EnableTransactionManagement:在配置类中加上,开启事务管理 需要在配置类中加入PlatformTransactionManager
PlatformTransactionManager接口定义了两个方法commit和rollback
public interface PlatformTransactionManager { TransactionStatus getTransaction(TransactionDefinition var1) throws TransactionException; void commit(TransactionStatus var1) throws TransactionException; void rollback(TransactionStatus var1) throws TransactionException;}
首先创建一个配置类:MainTxConfig
@EnableTransactionManagement //开启事务管理@ComponentScan("com.springTx") //扫描组件,这里扫描UserDao和UserService@Configurationpublic class MainTxConfig { /** * 配置数据源 * @return * @throws Exception */ @Bean public DataSource dataSorce() throws Exception { ComboPooledDataSource comboPooledDataSource = new ComboPooledDataSource(); comboPooledDataSource.setUser("root"); comboPooledDataSource.setPassword("123456"); comboPooledDataSource.setDriverClass("com.mysql.jdbc.Driver"); comboPooledDataSource.setJdbcUrl("jdbc:mysql://localhost:3306/study"); return comboPooledDataSource; } /** * jdbc模板操作数据库,这里需要获取到数据源,dataSorce()是从容器中获取已有的组件,而不是重新又创建一个数据源 * @return * @throws Exception */ @Bean public JdbcTemplate jdbcTemplate() throws Exception { return new JdbcTemplate(dataSorce()); } @Bean public PlatformTransactionManager platformTransactionManager() throws Exception { return new DataSourceTransactionManager(dataSorce()); }}
UserService
@Servicepublic class UserService { @Autowired private UserDao userDao; @Transactional public void insertUser(){ userDao.insert(); int n = 1/0; System.out.println("插入成功"); }}
UserDao:
@Repositorypublic class UserDao { @Autowired private JdbcTemplate jdbcTemplate; public void insert(){ String sql = "insert into user (name,age) value(?,?)"; String name = UUID.randomUUID().toString().substring(1,7); jdbcTemplate.update(sql,name, 20); }}
测试:
public class Txtest { @Test public void test(){ //创建容器 AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(MainTxConfig.class); UserService userService = applicationContext.getBean(UserService.class); userService.insertUser(); applicationContext.close(); }}
当出现异常时,事务会进行回滚操作。
Spring中怎么配置事务管理的详细内容,希望对您有所帮助,信息来源于网络。