如果在C#中使用TransactionScope类(分布式事务),则须注意如下事项:
1、在项目中引用using System.Transactions命名空间(先要在添加net组件的引用);

2、具体示例如下:
  


        /// <summary>
        
/// 发送消息
         
/// </summary>
        
/// <param name="sendUserId"></param>
        
/// <param name="toUser">格式7FFA3AF2-E74B-4174-8403-5010C53E49A7|userName,7FFA3AF2-E74B-4174-8403-5010C53E49A7|userName</param>
        
/// <param name="content"></param>
        
/// <param name="sendedStatus">表示已送</param>
        
/// <returns></returns>

        public static int sendMessage(string sendUserId, string toUser, string content, string sendedStatus)
        
{           
            
int receiveCount = 0;
            TransactionOptions transactionOption 
= new TransactionOptions();

            
//设置事务隔离级别
            transactionOption.IsolationLevel = System.Transactions.IsolationLevel.ReadCommitted;

            
// 设置事务超时时间为60秒
            transactionOption.Timeout = new TimeSpan(0060);

            
using (TransactionScope scope = new TransactionScope(TransactionScopeOption.Required, transactionOption))
            
{
                
try
                
{
                    
//在这里实现事务性工作
     
//发送消息
                    insertMessage(sendUserId, toUser, content, sendedStatus);

     
//在接收信息表中插入记录
                    receiveCount += insertReceiveMessage(userids[0], sendUserId, content, "0");
                   
                    
// 没有错误,提交事务
                    scope.Complete();
                }

                
catch (Exception ex) {
                    
throw new Exception("发送信息异常,原因:"+ex.Message);
                }finally{
                    //释放资源
                    scope.Dispose();
                  }
                               
            }

            
return receiveCount;
        }



 3、对MSDTC组件设置:
 步骤:
  在控制面板--->管理工具--->服务 中,开启Distributed Transaction Coordinator 服务。
 a.控制面板->管理工具->组件服务->计算机->我的电脑->右键->属性
 b.选择MSDTC页, 确认"使用本地协调器"
 c.点击下方"安全配置"按钮
 d.勾选: "允许网络DTC访问","允许远程客户端","允许入站","允许出站","不要求进行身份验证".
 e.对于数据库服务器端, 可选择"要求对呼叫方验证"
 f.勾选:"启用事务Internet协议(TIP)事务"。
 g.在双方防火墙中增加MSDTC.exe例外
   可用命令行: netsh firewall set allowedprogram %windir%\system32\msdtc.exe MSDTC enable

4、重启IIS服务器。

posted on 2009-03-17 17:02 aisoft 阅读(17001) 评论(3)  编辑  收藏 所属分类: .NET技术

FeedBack:
# re: C#语言中TransactionScope类的使用[未登录]
2012-01-12 14:05 | a
aaaaaa  回复  更多评论
  
# re: C#语言中TransactionScope类的使用[未登录]
2012-01-12 14:06 | a
a  回复  更多评论
  
# re: C#语言中TransactionScope类的使用
2012-09-29 10:44 | slx
微软这套分布式事务的方案,实在不怎么样. 居然还要设置数据库服务器的.如果其中一个数据库是Oracle安装在Lunix服务器上怎么搞?  回复  更多评论
  

只有注册用户登录后才能发表评论。


网站导航:
 
<2024年4月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

随笔档案(2)

文章分类(12)

文章档案(12)

收藏夹

搜索

  •  

最新评论