使用spring手动控制事务

[b]前言:[/b]
建议不要使用spring自动控制事务,一般不需要回滚的DAO方法(如查询),建议不要使用事务,由于使用事务的时候,会锁住表,过多的使用事务,可能会出现死锁的现象。单条更新语句也不需要使用事务,数据库会自动回滚。

[b]使用spring手动控制事务[/b]

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里定义。





class="org.springframework.transaction.support.TransactionTemplate">




另外设置 transactionManager 的 nestedTransactionAllowed 属性为 true可以实现嵌套事务, 此属性默认为 false。
关于嵌套事务见:[url]http://hi.baidu.com/injava/blog/item/484fd81b3f820cfeae51335e.html [/url]

你可能感兴趣的:(Java)