1. JDBC需要事务吗?
习惯里Spring JdbcTemplate的便捷性,一直以为JDBC不需要事务,但是仔细一想,如果有多条SQL语句同时执行,如何保证事务的完整性?
仔细阅读JdbcTemplate的源码,发现底层实现都依赖于DataSourceUtils,而它在获取数据连接时,是依赖于事务管理器的,如下:
public static boolean isConnectionTransactional(Connection con, DataSource dataSource) {
if (dataSource == null) {
return false;
}
ConnectionHolder conHolder = (ConnectionHolder) TransactionSynchronizationManager.getResource(dataSource);
return (conHolder != null && connectionEquals(conHolder, con));
}
且在Spring JDBC的使用中,官方推荐采用DataSourceTransactionM