mybatis在执行sql时,首先要去获取连接
具体代码位置,调用BaseExecutor.getConnection()方法去获取连接,进而调用transaction.getConnection()
transaction是在使用SqlSessionFactoryBean时注入,具体代码位置
SpringManagedTransaction.getConnection方法中就整合进了Spring的事物管理,如果配置了spring的事物,则82行代码获取的连接则是DataSourceTransactionManager创建的连接,也就是110行代码获取,如果没有配置则是由如下代码创建在115行,115行获取的连接是自动提交的。此时也没有使用spring的事物管理
当存在spring事物管理时,mybatis-spring的事物提交就交给spring了,如果不存在则在如下代码位置进行提交,不过这里提交已经没有任何作用了,因为可以从前面看到创建的连接是自动提交的