1.为什么要开启事务:举一个简单的例子:在银行业务中,有一条记账原则,即又借有贷。为了保证这种原则,每发生一笔银行业务,就必须保证会计账目上借方科目和贷方科目至少个少一笔,并且这两笔要么同时成功,要么同时失败。 事务是一个单个的工作单元。如果某一个事务成功,则在该事务中进行的所有数据更改均会提交,成为数据库中的永久部分。如果事务遇到错误,这时必须进行回滚操作,则所有数据更改均被清除。2.在C#中开启事务我们都知道在数据库中如何开启事务,那么如果想通过在C#中开启事务必须借助Transaction类。3.在C#中开启事务的步骤01.调用SqlConnection对象的BeginTransaction()方法,创建一个SqlTransaction对象,标志事务开始。02.将创建的SqlTransaction对象分配给要执行的SqlCommand的Transaction属性。03.调用相应的方法执行SqlCommand命令。04.调用SqlTransaction的Commit()方法完成事务。或调用Rollback()方法终止事务。 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如果添加成功放回1int count=cmd.ExecuteNonQuery();if (count > 0){MessageBox.Show("成功");//事务提交trans.Commit();}else {MessageBox.Show("失败");//事务回滚trans.Rollback();}}catch (Exception){//如果某个环节出现问题,则将整个事务回滚trans.Rollback();}本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-04/130479.htm