• ORM中启用数据库事务


    一、在mvc中使用事务

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

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


    这个批注的处理方式是,只要action发生了任何异常,数据库都会自动回滚。
    wojilu系统使用了大量的批注[特性,本人比较喜欢特性这个词语,鸡蛋同学喜欢批注这个词语]来控制Method,例如Action的权限验证,安全验证等等都是通过批注加反射来实现的。通过获取批注可以获得很多很多方法的信息。

    具体的实现方法:

     1     /// <summary>
     2     /// 在当前 action 上启用数据库事务,支持多数据库事务
     3     /// </summary>
     4     [Serializable, AttributeUsage( AttributeTargets.Method )]
     5     public class DbTransactionAttribute : Attribute, IActionFilter {
     6 
     7         private static readonly ILog logger = LogManager.GetLogger( typeof( DbTransactionAttribute ) );
     8 
     9         public void BeforeAction( ControllerBase controller ) {
    10 
    11             DbContext.beginAndMarkTransactionAll();
    12         }
    13 
    14         public void AfterAction( ControllerBase controller ) {
    15 
    16             if (controller.ctx.utils.getException() == null) {
    17                 DbContext.commitAll();
    18             }
    19             else {
    20                 try {
    21                     DbContext.rollbackAll();
    22                 }
    23                 catch (Exception ex) {
    24                     logger.Error( "data operation ( rollbackAll ):" + ex.StackTrace );
    25                     throw ex;
    26                 }
    27                 finally {
    28                     logger.Info( "DbTransaction : rollbackAll" );
    29                     DbContext.closeConnectionAll();
    30                 }
    31             }
    32 
    33         }
    34 
    35         public int Order { getset; }
    36 
    37     }


    二、手动使用事务

    // 启动事务
    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();
    // 更多代码 ...

    参考文章:阅读延伸

    wojilu系统的ORM介绍 

  • 相关阅读:
    Geogebra指令
    大表修改表结构
    mongodb获取配置参数getParameter
    mysql的binlog增量日志解析,提供增量数据订阅和消费
    chaosblade-exec-os项目的burnio.go文件解读
    mysql的where条件中的字段不要加函数
    mysql释放大表空间的正确之道
    mysql服务器问题
    purge binary logs to 'mysql-bin.039790';
    golang操作mysql数据库的规范
  • 原文地址:https://www.cnblogs.com/TextEditor/p/2090401.html
Copyright © 2020-2023  润新知