@Transactional注解的作用
时间: 2023-08-25 19:15:57 浏览: 101
引用在使用@Transactional注解时,需要注意保证方法的可见性,否则事务可能会失效。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [@Transactional](https://blog.csdn.net/seven_xjj/article/details/120100704)[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^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
相关问题
@Transactional注解作用
@Transactional注解的作用是用于控制事务的提交和回滚。在Spring框架中,当我们在一个方法上添加@Transactional注解时,该方法就成为一个事务方法。当该方法被调用时,Spring会自动为该方法创建一个事务,并在方法执行结束后根据方法的执行结果来决定是提交事务还是回滚事务。
@Transactional注解可以应用在类级别和方法级别上。当应用在类级别上时,表示该类的所有公共方法都将被视为事务方法。当应用在方法级别上时,表示该方法是一个事务方法。
@Transactional注解还可以指定事务的传播行为和隔离级别。传播行为用于控制事务在多个方法调用之间如何传播,例如REQUIRED表示如果当前存在事务,则加入该事务,如果不存在事务,则创建一个新的事务。隔离级别用于控制事务之间的隔离程度,例如READ_COMMITTED表示一个事务可以读取并修改已经提交的数据,但是不能读取未提交的数据。
总而言之,@Transactional注解提供了一种简单的方式来管理事务,确保数据的一致性和完整性。
@Transactional 注解作用
@Transactional注解是Spring框架中用于管理事务的注解。它可以作用于接口、类、类方法,并且可以配置多个属性信息。当放在类上时,表示该类的所有public方法都使用相同的事务属性信息;当放在方法上时,表示该方法使用自己的事务属性信息,会覆盖类的事务配置信息。@Transactional注解的属性包括propagation、isolation、timeout、readOnly、rollbackFor、noRollbackFor等。其中,propagation属性用于指定事务的传播行为,isolation属性用于指定事务的隔离级别,timeout属性用于指定事务的超时时间,readOnly属性用于指定事务是否只读,rollbackFor属性用于指定哪些异常需要回滚事务,noRollbackFor属性用于指定哪些异常不需要回滚事务。
示例代码如下:
```java
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserDao userDao;
@Override
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, readOnly = false, timeout = 36000, rollbackFor = Exception.class)
public void addUser(User user) {
userDao.addUser(user);
}
@Override
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, readOnly = false, timeout = 36000, rollbackFor = Exception.class)
public void updateUser(User user) {
userDao.updateUser(user);
}
@Override
@Transactional(propagation = Propagation.REQUIRED, isolation = Isolation.DEFAULT, readOnly = false, timeout = 36000, rollbackFor = Exception.class)
public void deleteUser(int userId) {
userDao.deleteUser(userId);
}
@Override
@Transactional(propagation = Propagation.SUPPORTS, isolation = Isolation.DEFAULT, readOnly = true, timeout = 36000, rollbackFor = Exception.class)
public User getUserById(int userId) {
return userDao.getUserById(userId);
}
@Override
@Transactional(propagation = Propagation.SUPPORTS, isolation = Isolation.DEFAULT, readOnly = true, timeout = 36000, rollbackFor = Exception.class)
public List<User> getAllUsers() {
return userDao.getAllUsers();
}
}
```
阅读全文