现在的位置: 首页 > 综合 > 正文

简述.net中有哪几种事务

2013年10月12日 ⁄ 综合 ⁄ 共 747字 ⁄ 字号 评论关闭

按事务是否跨越多数据资源来分类:

1)本地事务:事务操作一个数据资源,如数据库和消息队列。在物理上表现为位于同一台计算机。

2)分布事务:事务跨越多个数据源,如操作两个服务器上的数据库。

按事务处理方式划分:

1)手动事务:使用显示指令来控制事务的开始和结束,这种方式可以处理嵌套事务。SQLServer,ADO.NET都提供手动事务处理。

2)自动事务:通过有组件声明事务特性,把组件自动置于事务环境中。使用自动事务不能处理嵌套事务。自动事务的本质是依托于COM+。

本地事务的实现方式:

1) 数据库:一般DBMS都提供了自己的事务支持,如SqlServer,Oracle,属于手动处理方式。

2)ADO.Net:使用 Connection 和 Transaction对象来控制事务。Connection.BeginTransaction 启动本地事务; Command 对象的 Transaction属性在该事务中登记命令;然后 Transaction 对象提交或回滚在数据源中所做的修改。也属于手动处理方式。

3)使用消息队列:内部事务使用MessageQueueTransaction,属于手动处理;外部事务则要用自动事务处理方式。

分布式事务的实现:

1)数据库之间的事务:

    手动处理方式:对每一个参与的原子操作用一个Trans来控制;当最后一个操作执行成功后,事务全部提交;其中一个出错或异常,事务全部回滚。

   自动处理方式:借助于.Net EnterpriseServices提供的自动事务处理。

2)不同类型数据资源之间:

借助于.Net EnterpriseServices提供的自动事务处理。当然,可以用COM+实现事务。

http://wangzhiyu110.blog.sohu.com/156427139.html

抱歉!评论已关闭.