asp.net创建事务的方法

1、建立List用于存放多条语句

    /// <summary>
    /// 保存表单
    /// </summary>
    /// <param name="context"></param>
    protected void save()
    {
        List<string> list = new List<string>();
        list.Add(string.Format("insert into picsone(model,idser,idflg,lmuser,lmdate,lmtime) values('{0}','{1}','{2}','{3}',{4},{5})", "T1002", "Y", "N", "U001", 20161103, 140025));
        list.Add(string.Format("insert into picstwo(model,idser,idflg,lmuser,lmdate,lmtime) values('{0}','{1}','{2}','{3}',{4},{5})", "T1002", "Y", "N", "U001", 20161103, 140025));
        bool bol = ExecuteTransaction(list);
        if (bol)
        {
            MessageBox.Show("保存成功!");
        }
        else
        {
            MessageBox.Show("保存失败!");
        }
    }

2、调用ExecuteTransaction方法,并返回返回值true为成功,false为失败,语句并回滚

    /// <summary>
    /// 执行语句
    /// </summary>
    /// <param name="list"></param>
    /// <returns></returns>
    private bool ExecuteTransaction(List<string> list)
    {
        using (SqlConnection connection = new SqlConnection(ConfigurationManager.AppSettings["LocalConnectionString"].ToString()))
        {
            SqlCommand command = new SqlCommand();
            SqlTransaction transaction = null;
            try
            {
                connection.Open();
                transaction = connection.BeginTransaction();
                command.Connection = connection;
                command.Transaction = transaction;

                for (int i = 0; i < list.Count; i++)
                {
                    command.CommandText = list[i];
                    command.ExecuteNonQuery();
                }

                transaction.Commit();
                connection.Close();
                return true;
            }
            catch
            {
                transaction.Rollback();
                connection.Close();
                return false;
            }
        }
    }

  

转载于:https://www.cnblogs.com/lengzhan/p/6026375.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值