springboot @Transactional用法
时间: 2023-12-12 08:34:44 浏览: 32
在SpringBoot中,@Transactional注解用于配置事务。当我们在方法或类上添加@Transactional注解时,SpringBoot会自动将该方法或类纳入Spring的事务管理中。下面是一个使用@Transactional注解的例子:
```java
@Transactional(readOnly = false, isolation = Isolation.READ_COMMITTED, rollbackFor = Exception.class)
public void updateUserInfo(UserInfo userInfo) {
// 更新用户信息的代码
}
```
在上面的例子中,@Transactional注解被添加到了updateUserInfo方法上。其中,readOnly属性表示是否只读,默认为false;isolation属性表示事务的隔离级别,默认为Isolation.DEFAULT;rollbackFor属性表示需要回滚的异常类型,默认为RuntimeException.class。
相关问题
springboot@transactional使用
在Spring Boot中使用@Transactional注解需要在启动类上添加@EnableTransactionManagement注解。事务管理是应用系统开发中不可或缺的一部分,Spring为事务管理提供了丰富的功能支持。在Spring项目中,默认情况下,@Transactional注解会回滚运行时异常及其子类,而其他范围之外的异常不会被Spring回滚数据。如果我们也想要回滚其他异常,可以在方法或类上加上@Transactional(rollbackFor = Exception.class)注解。
Spring本身没有事务,只有数据库才有事务。Spring的事务是通过AOP和动态代理实现的。在我们操作数据库时,实际上是通过动态代理进行功能扩展。在代码操作数据库之前,Spring会通过数据库客户端打开数据库事务。如果代码执行完毕没有异常信息或者没有Spring要捕获的异常信息,Spring会通过数据库客户端提交事务。如果有异常信息或者有Spring要捕获的异常信息,Spring会通过数据库客户端程序回滚事务,从而控制数据库事务。
以下是一些使用@Transactional注解的代码示例:
```java
@Service
public class UserService {
@Autowired
private UserRepository userRepository;
@Transactional
public void createUser(User user) {
userRepository.save(user);
}
@Transactional(rollbackFor = Exception.class)
public void updateUser(User user) {
userRepository.save(user);
}
@Transactional(propagation = Propagation.REQUIRED)
public void deleteUser(Long userId) {
userRepository.deleteById(userId);
}
}
```
在上面的代码示例中,@Transactional注解应用于方法上,表示这些方法会在数据库事务中运行。createUser方法和updateUser方法使用了默认的事务回滚策略,即回滚运行时异常及其子类。deleteUser方法使用了REQUIRED传播行为,表示如果当前没有事务,则创建一个新的事务;如果当前已经存在事务,则加入到当前事务中。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [SpringBoot 中 @Transactional 的使用细节](https://blog.csdn.net/Yue_zuozuo/article/details/84823490)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [【Java 基础】SpringBoot 中 @Transactional 注解的使用与实践](https://blog.csdn.net/yuxiangdeming/article/details/125243814)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
springboot @Transactional无效
在Spring Boot中,使用@Transactional注解来实现声明式事务管理是非常方便的。然而,有几个可能导致@Transactional注解无效的原因。
首先,根据引用\[1\],如果在捕获异常的同时抛出了异常,事务将不会回滚。这意味着在异常处理过程中,需要确保不再抛出异常,以便事务能够正常回滚。
其次,根据引用\[2\],如果@Transactional注解应用在非public修饰的方法上,事务将会失效。这意味着@Transactional注解应该应用在public修饰的方法上,以确保事务能够正确地被管理。
此外,根据引用\[3\],如果@Transactional注解应用在protected或private修饰的方法上,事务虽然无效,但不会报错。这是一个容易犯错的地方,需要注意。
综上所述,如果在Spring Boot中使用@Transactional注解无效,可以检查是否在异常处理过程中抛出了异常,以及是否将注解应用在public修饰的方法上。
#### 引用[.reference_title]
- *1* [SpringBoot @Transactional 事务 注解 失效](https://blog.csdn.net/tianshi527/article/details/111236464)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [springboot中使用@Transactional注解事物不生效的原因(数据库事务隔离机制以及传播机制传播行为)](https://blog.csdn.net/zy103118/article/details/122296318)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
- *3* [springboot 注解@Transactional失效的原因](https://blog.csdn.net/kang1011/article/details/121451324)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]