前言:
建议不要使用spring自动控制事务,一般不需要回滚的DAO方法(如查询),建议不要使用事务,由于使用事务的时候,会锁住表,过多的使用事务,可能会出现死锁的现象。单条更新语句也不需要使用事务,数据库会自动回滚。
使用spring手动控制事务
Java代码
private DataSourceTransactionManager transactionManager;
public DataSourceTransactionManager getTransactionManager() {
return transactionManager;
}
public void setTransactionManager(
DataSourceTransactionManager transactionManager) {
this.transactionManager = transactionManager;
}
//无返回值,用这个
public void deleteGroups(final String... groupIds)
{
new TransactionTemplate(transactionManager).execute(new TransactionCallbackWithoutResult() {
protected void doInTransactionWithoutResult(TransactionStatus status) {
//调用DAO按照ID删除部门
}
});
}
//有返回值,用这个
public int deleteGroups(final String... groupIds)
{
return (int) new TransactionTemplate(transactionManager).execute(new TransactionCallback() {
public String doInTransaction(TransactionStatus status) {
return //调用DAO按照ID删除部门;
}
});
在deleteGroups方法里手动控制事务,将你调用DAO方法的代码写在doInTransationWithResult里写的方法,只要抛出运行时异常,doInTransactionWithoutResult方法里的数据库操作都会被回滚。
注意:你必须传入一个DataSourceTransactionManager进去,这个你可以在bean.xml里定义。
Xml代码
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="transactionTemplate"
class="org.springframework.transaction.support.TransactionTemplate">
<property name="transactionManager" ref="transactionManager" />
</bean>
另外设置 transactionManager 的 nestedTransactionAllowed 属性为 true可以实现嵌套事务, 此属性默认为 false。
关于嵌套事务见:[url]http://hi.baidu.com/injava/blog/item/484fd81b3f820cfeae51335e.html [/url]