1.事务是什么?在MySQL中是怎么去开启,提交,回滚事务的。
事务 是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作请求,即这些操作 要么同时成功,要么同时失败。
在MySQL中:
开启事务(一组操作开始前,开启事务):start transaction / begin ;
提交事务(这组操作全部成功后,提交事务):commit ;
回滚事务(中间任何一个操作出现异常,回滚事务):rollback ;
2.在Spring中怎么管理事务,用什么注解,在那个层次进行使用可以有效管理事务
注解:@Transactional
位置:业务(service)层的方法上、类上、接口上
开启管理日志:
logging:
level:
org.springframework.jdbc.support.JdbcTransactionManager: debug
3.事务管理时规则:如果方法能够正常执行完自动提交事务,如果出现异常自动回滚事物。事务默认识别的异常是运行时异常,如果想要识别到编译时异常从而实现回滚,该怎么操作?
事务管理注解@Transactional中的rollbackFor属性默认情况下,只有出现RuntimeException才回滚异常。而如果出现编译时异常,则不回滚
如果想要实现编译时异常回滚,有两种方法
第一种方法是直接甩锅抛出异常,设置rollbackFor属性值为Exception.class,支持多态
// 删除部门
@Override
@Transactional(rollbackFor = Exception.class)
public void deleteDept(Integer id) throws FileNotFoundException{
// 删除部门
deptMapper.deleteById(id);
// 模拟编译时异常
new FileInputStream("***/***/***.txt");
// 删除该部门对应的员工
empMapper.deleteByDeptId(id);
}
第二种方法是使用try,catch语句捕获编译异常,在catch中抛出(throw)运行异常完成转换,从而实现回滚
// 删除部门
@Override
@Transactional //Spring事务管理
public void deleteDept(Integer id){
// 删除部门
deptMapper.deleteById(id);