zoukankan      html  css  js  c++  java
  • c# 事物处理

    对两个数据表同时进行insert操作处理,对它们的插入操作要么全部成功,要么都插入失败,否则只插入一个表成功会引起数据库的不一致。很显然,这是一个事务处理(transcation),要么commit成功,要么则rollback。在代码中,利用C#中提供的Transcation类来实现,代码如下:

            private void btn_submit_Click(object sender, System.EventArgs e)
            {
                string strconn = ConfigurationSettings.AppSettings["dsn"];
                SqlConnection cnn = new SqlConnection(strconn);
                SqlCommand cmd = new SqlCommand();
                SqlTransaction transaction = null;

                try
                {
                    cnn.Open();
                    // 先插入分店shop表,再插入经理Manager表,并将其作为一个事务进行处理
                    transaction = cnn.BeginTransaction();//启动事物
                    cmd.Transaction = transaction;
                    cmd.Connection = cnn;

                    // 插入分店shop表
                    string shopstr = "insert into shop values('" + tbx_shopid.Text + "','" + tbx_shopname.Text + "','" + tbx_shopaddress.Text + "','" + tbx_shopphone.Text + "')";
                    cmd.CommandType = CommandType.Text;
                    cmd.CommandText = shopstr;
                    cmd.ExecuteNonQuery();

                    // 插入经理Manager表
                    string managerstr = "insert into manager values('" + tbx_managerid.Text + "','" + tbx_managerpassword.Text + "','" + tbx_managername.Text + "','" + tbx_shopid.Text + "')";
                    cmd.CommandType = CommandType.Text;
                    cmd.CommandText = managerstr;
                    cmd.ExecuteNonQuery();

                    // 提交事务
                    transaction.Commit();
                    lbl_msg.Text = "添加分店操作成功";
                }
                catch(Exception ex)
                {
                    lbl_msg.Text = "添加分店操作失败";
                    transaction.Rollback();//发生回滚
                }
                finally
                {
                    cnn.Close();
                }
            }

    另一种方法 TransScope

    如果在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服务器。

  • 相关阅读:
    JavascriptCore中扩展自定义函数
    Qt for Symbian应用的开发转载
    Qt Symbian 开发环境安装转载
    qt屏幕抓图
    为JavascriptCore添加自定义对象
    Tesseract OCR开源项目转载
    Joomla, Wordpress, Drupal 全面详细Pk比较转载
    Drupal,Joomla,Wordpress在内置应用功能方面的区别和比较转载
    Docker:第五章:基于centos7的docker安装配置部署教程以及基于docker Tomcat镜像使用的项目部署教程
    【JavaP6大纲】Redis篇:redis集群工作原理,协议,分布式寻址算法
  • 原文地址:https://www.cnblogs.com/codeloves/p/2957831.html
Copyright © 2011-2022 走看看