如果没有显示的声明 在抛出IO异常和SQL异常等(及其子类) 可检查性异常时,不会进行回滚
可检查性异常:非运行时异常 (在编译前就可以检测出来 最直观的体现是在IDE中直接爆红 让我们进行处理)
不可检异常: 运行时异常 (运行时候才报错 在运行前检测不出来)
举例:
......
@Transactional
public void method(Entity e) throws FileNotFoundException{
// 数据库中插入了e的数据
// FileNotFoundException是IO异常的子类 不进行回滚
xxMapper.addEntity(e);
File file = new File("/xxx");
InputStream is = new FileInputStream(file);
}
为什么使用mybatis的baseMapper.xxx()方法时 即使是sql写错了 ,可能也进行了回滚?
源码内部进行了处理 将SQL异常捕获 , 将日志打印出控制台
我们IDE看到的sqlException报错 是日志信息。
如果使用传统的JDBC四步骤 执行sql 出现异常时,就不会发生回滚 所以SQL异常抛出不回滚 结论是正确的。
注意: 如果是try catch了 捕获了异常 事务是不会回滚的
下面截图是我在mybatis plus中 测试一个sql有问题的方法,即上文提到的baseMapper.xxx()
那为什么显示指定的是Exception.class呢?
因为可检查异常 (sql,io异常) 都是Exception的子类,
不指定的话 其实就相当于默认是rollbackFor = RuntimeException.class
error是一定回滚的
下面是Throwable结构图