如何配置以在Spring + JDBC中关闭自动提交?

我在JDBC中使用Spring,发现它是自动提交的。

如何配置以在spring-servlet.xml中将其关闭?

这是我当前的配置:

<bean id="dataSource"

class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"

p:driverClassName="${jdbc.driverClassName}"

p:url="${jdbc.databaseurl}" p:username="${jdbc.username}"

p:password="${jdbc.password}" />

<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">

<property name="dataSource" ref="dataSource"/>

</bean>

回答:

看来我的配置错过了这一行:

<tx:annotation-driven transaction-manager="txManager"/>

然后,在我的服务类中,我使用@Transactional批注。例如

@Service

class CompanyServiceImpl implements CompanyService{

@Autowired

private CompanyDAO companyDAO;

@Transactional

public void addCompany(Company company) {

companyDAO.addCompany(company); // in here, there is JDBC sql insert

companyDAO.addCompany_fail(company); // just for test

}

}

如果addCompany_fail()中发生异常,则第一个addCompany()也将被回滚。

我阅读了这份文档,以了解在Spring中如何控制事务。

http://static.springsource.org/spring/docs/3.0.x/spring-framework-

reference/html/transaction.html

我阅读了本文档,以了解如何在Spring中使用JDBC进行编码。

http://static.springsource.org/spring/docs/3.0.x/spring-framework-

reference/html/jdbc.html

我还阅读了这个(免费)http://www.infoq.com/news/2009/04/java-transaction-models-

strategy。真的很好。我对作者的看法是,大多数人都不了解(或关心)交易。

PS:似乎很多人误解了使用这种Hibernate / Spring框架只是为了避免JDBC和事务控制的复杂性。许多人认为,“

JDBC和事务是如此复杂,只需使用Hibernate而不用考虑这两者”。互联网上有关Spring + Hibernate或Spring +

JDBC的许多示例似乎根本不在乎事务。我觉得这是个坏笑话。交易太严重了,以至于在没有真正理解的情况下让某些事情来处理。

Hibernate和Spring是如此强大且如此复杂。然后,就像有人说的那样,“强大的力量伴随着责任”。

**更新:2013-08-17:** http **://www.byteslounge.com/tutorials/spring-

transaction-propagation-tutorial上**

有一个很好的交易示例。但是,这并不能说明如果您想使用REQUIRES_NEW,为什么需要创建另一个类(否则,您将遇到此问题:Spring事务传播为REQUIRED,REQUIRES_NEW,看来REQUIRES_NEW并没有真正创建新的事务)

我已创建了春天引导1.5.8.RELEASE一个完整的例子这里https://www.surasint.com/spring-boot-database-

transaction-jdbi/ 这里一些基本的实验例子HTTPS ://www.surasint.com/spring-boot-connection-

transaction/

以上是 如何配置以在Spring + JDBC中关闭自动提交? 的全部内容, 来源链接: utcz.com/qa/408796.html

回到顶部