图文演示WCF事物操作

开发 后端
这里对常见WCF事物操作分析一下,对TransactionFlowBindingElement、TransactionFlow的在应用的使用也列举了案例详细说明,希望对大家有帮助。

对于有经验的人来说,处理事务还是比较容易的事情,但是对于向我们这让的新手来说WCF事物操作的实现会给我们编程带来什么样的阻力可想而知,这里我们就简单的分析一下。

#T#指定了TransactionFlow(TransactionFlowOption.Mandatory),而Binding却没有设置TransactionFlow为true 此时会出现类似"Bank"协定上至少有一个操作配置为将属性设置为"强制",但是通道的绑定"WSDualHttpBinding"未使用 TransactionFlowBindingElement 进行配置。没有 TransactionFlowBindingElement,无法使用设置为"强制"的 TransactionFlowAttribute 属性。WCF事物操作错误提示。

 WCF事物操作错误提示 


设置了[OperationBehavior(TransactionScopeRequired=true)]的操作,却没有在TransactionScorp中执行,会发生类似"服务操作需要事务成为流"的异常,截图如下:

服务操作需要事务成为流

也许上面两个问题都是不是问题的问题,那这一点的确是需要我们研发人员注意的,否则我们会吃亏不少。这点涉及到事务和服务实例模式的联系,我们通过学习WCF从理论到实践:实例模式和对象生命周期 我们都学习到了实例在PerSession或者Single模式下不会每次都创建和消亡,这的确是一个不争的真理,可在这里却受到了挑战,不信你可以编写一个程序,即使用你最放心的Single模式,那时不是就是说服务实例是一次创建,终身受用呢?下面就看看我***次编写范例程序后得到的运行结果,我如下定义Bank

编写范例程序

可在调用的时候,我却发现了一个很奇怪的问题,按照理论来说,Bank服务实例应该只创建一次,可运行的截图却是如下:

 Bank服务实例

这个结果是不是令大家大失所望呢?这是因为实现了事务的得服务还要受到TransactionAutoCompleteOnSessionClose的限制,该属性默认情况是true,它指示 在WCF事务操作完成之后强制销毁服务实例,相当于调用服务的Dispose()方法进行释放,尽管是PerSession或者Single都难逃它的法网。如果想维持实例模式,可以将其设置为false,更改后运行效果便可如期望一致效果图不再给出。

责任编辑:田树 来源: 博客
相关推荐

2009-11-05 16:34:37

WCF序列化

2009-11-05 09:35:54

WCF体系架构

2009-11-09 16:14:49

WCF服务元数据

2009-11-09 13:04:53

WCF事物处理

2009-11-06 09:30:35

WCF服务框架

2010-03-02 13:43:01

WCF事务演示

2009-11-12 09:51:59

ADO.NET结构

2009-11-05 10:07:37

WCF设计模式

2009-11-06 15:02:47

WCF契约查询

2010-03-02 14:12:30

WCF枚举类型

2011-12-26 16:33:02

WCF

2010-12-24 14:12:00

umask命令

2010-03-01 15:27:35

WCF分布操作

2009-11-05 14:25:36

WCF Data Co

2009-10-29 10:00:53

ADO.NET数据集

2010-03-01 15:08:05

WCF单向操作

2009-11-09 11:31:47

WCF消息队列

2023-03-02 07:37:53

2009-11-05 16:21:51

WCF服务

2009-11-06 16:35:56

WCF Stream对
点赞
收藏

51CTO技术栈公众号