WCF控制事务具体操作代码解读

开发 开发工具
WCF控制事务其实是在服务器端上进行控制的。我们接下来将会通过一段代码示例来为大家详细解读相关操作方法,方便大家理解。

WCF开发工具中对于事务的相关处理是一个比较重要的操作技术,我们在学习的过程中需要对此加强注意力。把事务放到客户端控制,实际上WCF控制事务还是在服务器端的,只不过操作权给了客户端而已。思路和WebService实现是一样的,即用WCF的状态化记住控制事务所需的对象,然后给客户端提供接口来操作这些对象。

闲话少说,WCF控制事务代码如下:

服务器端代码:

  1. [ServiceContract(SessionModeSessionMode=SessionMode.Required)]  
  2. public interface IMyService{  
  3. [OperationContract(IsTerminating=true)]  
  4. void ReleaseSession();  
  5. [OperationContract]  
  6. void BeginTransaction();  
  7. [OperationContract]  
  8. void CommitTransaction();  
  9. [OperationContract]  
  10. void RollbackTransaction();  
  11. [OperationContract]  
  12. int ExecuteNonQuery(string strCmdText);}  
  13. [ServiceBehavior(InstanceContextModeInstanceContextMode=
    InstanceContextMode.PerSession)]  
  14. public class MyService : IMyService{private string strConnString =
     "
    server=namihei2\\KHOS;database=AEGIS_TEST;  
  15. uid=sa;pwd=Password01!";  
  16. private SqlConnection mySqlConnection;  
  17. private SqlTransaction mySqlTransaction;  
  18. public void ReleaseSession(){  
  19. if (mySqlConnection.State == ConnectionState.Open)
    {mySqlConnection.Close();  
  20. }}  
  21. public void BeginTransaction(){  
  22. mySqlConnection = new SqlConnection(strConnString);  
  23. mySqlConnection.Open();  
  24. mySqlTransaction = mySqlConnection.BeginTransaction();  
  25. }  
  26. public void CommitTransaction(){  
  27. mySqlTransaction.Commit();  
  28. }  
  29. public void RollbackTransaction(){mySqlTransaction.Rollback();  
  30. }  
  31. public int ExecuteNonQuery(string strCmdText)  
  32. {  
  33. try{SqlCommand objSqlCommand = new SqlCommand(strCmdText);  
  34. objSqlCommand.Connection = mySqlConnection;  
  35. objSqlCommand.Transaction = mySqlTransaction;  
  36. return objSqlCommand.ExecuteNonQuery();  
  37. }  
  38. catch (Exception ex){  
  39. throw new FaultException(ex.Message);  
  40. }}}  

客户端代码:

  1. static void Main(string[] args){  
  2. Console.WriteLine("Session Transaction Begin");  
  3. SessionTrans.MyServiceClient serviceProxy = 
    new ConsoleTest.SessionTrans.MyServiceClient();  
  4. try{serviceProxy.BeginTransaction();  
  5. serviceProxy.ExecuteNonQuery("update ATMAccount set Amount = 1000");  
  6. serviceProxy.ExecuteNonQuery("insert into ATMLog
    (AccountNumber,OperationType)  
  7. values ('888', 'good')");  
  8. //serviceProxy.ExecuteNonQuery("insert into ATMLog
    (AccountNumber,OperationType)   
  9. values ('888', 'goodgoodgoodgoodgoodgoodgoodgoodgoodgoodgoodgood
    goodgoodgoodgoodgood')");  
  10. serviceProxy.CommitTransaction();  
  11. }  
  12. catch (Exception ex){Console.WriteLine(ex.Message);  
  13. serviceProxy.RollbackTransaction();  
  14. }  
  15. finally{serviceProxy.ReleaseSession();  
  16. serviceProxy.Close();  
  17. }  
  18. Console.WriteLine("Session Transaction End");  
  19. Console.Read();  

以上就是对WCF控制事务的相关介绍。

【编辑推荐】

  1. WCF框架基本解析方式介绍
  2. WCF端点配置正确编程方式解读
  3. WCF服务合同基本内容概述
  4. WCF行为控制代码示例应用解读
  5. WCF宿主模式主要概念总结
责任编辑:曹凯 来源: qqread.com
相关推荐

2010-02-24 13:06:27

WCF使用Nhiber

2010-03-02 09:39:11

保护WCF服务

2010-03-01 14:56:48

WCF服务引用

2010-03-01 17:28:25

WCF Stream对

2010-02-24 17:41:05

WCF集合反序列化

2010-03-02 14:41:00

WCF行为控制

2009-12-30 15:47:40

Silverlight

2011-03-17 09:06:58

iptables映射端口

2010-08-02 17:20:12

nfs启动Linux

2010-07-26 13:30:23

2009-12-31 15:36:13

SilverLight

2010-08-02 12:34:09

ADSL代理设置

2009-12-31 15:36:13

SilverLight

2010-05-27 14:29:53

Linux查看进程

2009-12-09 09:28:12

配置静态路由

2009-12-30 16:48:52

Silverlight

2010-07-15 19:46:40

关闭Telnet 23

2010-04-02 08:42:32

Oracle 游标

2010-04-01 17:25:46

Oracle死锁进程

2010-02-03 13:26:53

C++计时
点赞
收藏

51CTO技术栈公众号