C# 事务的创建,提交和回滚

在C#中开启事务的步骤

01.调用SqlConnection对象的BeginTransaction()方法,创建一个SqlTransaction对象,标志事务开始。

02.将创建的SqlTransaction对象分配给要执行的SqlCommand的Transaction属性。

03.调用相应的方法执行SqlCommand命令。

04.调用SqlTransaction的Commit()方法完成事务。或调用Rollback()方法终止事务。  

4.在进行事务操作中的注意点

01.在调用BeginTransaction()方法开始事务之前,要打开数据库连接,否则出现异常。

02.如果在事务的Commit()方法或RollBack()方法执行前数据库连接断开或关闭,则事务将回滚。

            //准备连接字符串
            string str = "data source=.;initial catalog=Myschool;uid=sa;pwd=123";
            //创建数据库连接对象
            SqlConnection con = new SqlConnection(str);
            //sql语句:添加一条记录到年级表
            string sql = "insert into grade values(@gradename)";
            //创建SqlParameter对象,设置参数
            SqlParameter sp = new SqlParameter("@gradename", txtgradename.Text);
            //创建命令对象
            SqlCommand cmd = new SqlCommand(sql, con);
            //通过Parameter集合的add()方法天填充参数集合
            cmd.Parameters.Add(sp);
            //打开连接
            con.Open();
            //默认让SqlTransaction对象为空
            SqlTransaction trans = null;
            //开启事务:标志事务的开始
            trans = con.BeginTransaction();
            try
            {
                //将创建的SqlTransaction对象分配给要执行的sqlCommand的Transaction属性
                cmd.Transaction = trans;
                //执行sql如果添加成功
                int count = cmd.ExecuteNonQuery();
                if (count >= 0)
                {
                    MessageBox.Show("成功");
                    //事务提交
                    trans.Commit();
                }
                else
                {
                    MessageBox.Show("失败");
                    //事务回滚
                    trans.Rollback();
                }
            }
            catch (Exception)
            {
                //如果某个环节出现问题,则将整个事务回滚
                trans.Rollback();
            }

使用事务一次处理多条SQL语句的方法,包括SQL中事务的写法以及调用的方法

执行一个操作时,要同时修改多张表里的数据,并且每条数据都必须操作成功,才算执行成功,为了防止有些数据操作失败,有些成功,而造成的数据错乱,我们要使用事务。

事务就是:只有所有操作都成功则成功,只要有一条数据操作失败,则回滚。

        /// <summary>
        /// 执行多条SQL语句,实现数据库事务。
        /// </summary>sql2000数据库
        /// <param name="SQLStringList">多条SQL语句</param>
        public static void ExecuteSqlTran(List<string> SQLStringList)
        {
            using (SqlConnection conn = new SqlConnection(SqlHelper.ConString))
            {
                conn.Open();
                SqlCommand cmd = new SqlCommand();
                cmd.Connection = conn;
                SqlTransaction tx = conn.BeginTransaction();
                cmd.Transaction = tx;
                bool isSucss = true;
                try
                {
                    for (int n = 0; n < SQLStringList.Count; n++)
                    {
                        string strsql = SQLStringList[n].ToString();
                        if (strsql.Trim().Length > 1)
                        {
                            cmd.CommandText = strsql;
                            cmd.ExecuteNonQuery();
                        }
                    }
                   
                }
                catch (System.Data.SqlClient.SqlException E)
                {
                    isSucss = false;
                    tx.Rollback();
                    throw new Exception(E.Message);
                }
                finally
                {
                    if(isSucss )
                    {
                        tx.Commit();
                    }
                }

            }
        }

        private void button1_Click(object sender, EventArgs e)
        {

            try
            {
                //写SQL语句
                List<string> SQLStringList = new List<string>();
                string clickSql = "insert into [user] (name,age) values ('小名 ','4岁')";
                string userSql = "update [class] set [name]='幼儿园' where id=2";
                SQLStringList.Add(clickSql);
                SQLStringList.Add(userSql);
                ExecuteSqlTran(SQLStringList);
            }
            catch (Exception ex)
            {
                MessageBox.Show("操作失败!" + ex.Message); //输出
            }
        }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值