词条统计
浏览次数:5709 次
编辑次数:1次 历史版本
最近更新:2013/6/20
创建者:掷鸡蛋者


一、在mvc中使用事务

我记录 mvc 框架已经集成了数据库事务处理,启用事务的做法很简单,只要在action上面打上[DbTransaction]批注(attribute)即可,比如:

[HttpPost, DbTransaction]
public void Create() {
}


这个批注的处理方式是,只要action发生了任何异常,数据库都会自动回滚。

二、手动使用事务

// 启动事务
DbContext.
beginTransactionAll();

// 提交
DbContext.
commitAll();

// 回滚
try {
DbContext.
rollbackAll();
}
catch (Exception ex) {
// 处理异常
}
finally {
// 关闭数据库连接
DbContext.
closeConnectionAll();
}


解释一下,为什么这里是 beginTransactionAll,而不是 beginTransaction?因为wojilu ORM支持多数据库,也许你一个数据插入涉及到两个表,这两个表却分布在两个不同的数据库上,这种情况下,wojilu ORM会打开两个connection,使用beginTransactionAll方法,会同时针对这两个连接启用事务。在 commitAll 的过程中,任何一个发生异常,rollbackAll 会回滚这两个数据库操作,最后,closeConnectionAll也会同时关闭这两个数据库连接。

也就是说,wojilu是天然支持分布式数据库事务的


三、针对特定“数据库连接(connection)”手动管理事务

如果你需要手动写sql语句,或者非常明确你的事务只针对特定的数据库,你可以跳开wojilu ORM提供的方法,采用原始的.net数据库操作方式。

1)首先获得当前的数据库连接
IDbConnection connection = DbContext.getConnection( type );

2)然后在这个connection上启用事务管理,接下来的过程就和常规的数据库处理一样了,比如
connection.BeginTransaction();
// 更多代码 ...