在C#中开启事务

 1.为何要开启事务:sql

举一个简单的例子:在银行业务中,有一条记帐原则,即又借有贷。为了保证这种原则,每发生一笔银行业务,就必须保证会计帐目上借方科目和贷方科目至少个少一笔,而且这两笔要么同时成功,要么同时失败。  数据库

   事务是一个单个的工做单元。若是某一个事务成功,则在该事务中进行的全部数据更改均会提交,成为数据库中的永久部分。若是事务遇到错误,这时必须进行回滚操做,则全部数据更改均被清除。ui

2.在C#中开启事务spa

咱们都知道在数据库中如何开启事务,那么若是想经过在C#中开启事务必须借助Transaction类。code

3.在C#中开启事务的步骤对象

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

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

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

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

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

01.在调用BeginTransaction()方法开始事务以前,要打开数据库链接,不然出现异常。

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

5.添加年级信息时候的事务处理例子

 //准备链接字符串
            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若是添加成功放回1
                int count=cmd.ExecuteNonQuery();
                if (count > 0)
                {
                    MessageBox.Show("成功");
                    //事务提交
                    trans.Commit();
                }
                else 
                {
                    MessageBox.Show("失败");
                    //事务回滚
                    trans.Rollback();
                }
            }
            catch (Exception)
            {
                //若是某个环节出现问题,则将整个事务回滚
                trans.Rollback();
            }
相关文章
相关标签/搜索