使用事务的代码


                           using (SqlConnection sqlCon = SqlServerBeans.My_con)
                            {
                                SqlCommand command = new SqlCommand();
                                command.Connection = sqlCon;
                                //sqlCon.Open();
                                SqlTransaction trans = sqlCon.BeginTransaction();
                                try
                                {
                                    foreach (readText.sysChecklist sc in rptd_alst)
                                    {//
                                        count++;


                                        #region SQL字符串 insSql
                                        StringBuilder sb = new StringBuilder("insert into tb1 values( '");
                                        sb.Append("'same string')");// 
                                      
                                        
                                        #endregion

                                        string insSql = sb.ToString();
                                        Console.WriteLine(count + " _$_ " + insSql);
                                        command.CommandText = insSql;
                                        //cm.CommandTimeout = 20;
                                        command.Transaction = trans;
                                        command.ExecuteNonQuery();
                                    }//foreach end 
                                    trans.Commit();
                                    //将这张表,表头成功状态
                                    string uptSql = "update [tbHead] set [RptStatus] ='OK' where [ImpID] = " + strImpId;
                                    beans.getsqlcom(uptSql);
                                    MessageBox.Show("导入成功!", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
                                }
                                catch (Exception ex)
                                {
                                    Console.WriteLine("Commit Exception Type: {0}", ex.GetType());
                                    Console.WriteLine("  Message: {0}", ex.Message);
                                    MessageBox.Show("导入不成功", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Warning );

                                    // Attempt to roll back the transaction.
                                    try
                                    {
                                        trans.Rollback();
                                    }
                                    catch (Exception ex2)
                                    {
                                        // This catch block will handle any errors that may have occurred
                                        // on the server that would cause the rollback to fail, such as
                                        // a closed connection.
                                        Console.WriteLine("Rollback Exception Type: {0}", ex2.GetType());
                                        Console.WriteLine("  Message: {0}", ex2.Message);
                                    }
                                }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值