JDBC事务与ORM事务管理的差异与联系

本文探讨了JDBC是否需要事务,ORM事务的用途,一个应用程序是否能支持多个事务管理器,以及JDBC事务是否会影响ORM事务。JDBC虽然在Spring中默认配置事务管理,但在没有事务管理的情况下仍可操作数据库。ORM事务则需要配置,不仅管理数据库操作,还涉及缓存管理。一个应用可以有多个事务管理器,而JDBC与ORM事务通常互不影响,但可能影响缓存效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值