什么是事务?
事务:是数据库操作的最小工作单元,是作为单个逻辑工作单元执行的一系列操作;这些操作作为一个整体一起向系统提交,要么都执行、要么都不执行;事务是一组不可再分割的操作集合(工作逻辑单元);
事务的四大特性:
1 、原子性
事务是数据库的逻辑工作单位,事务中包含的各操作要么都做,要么都不做
2 、一致性
事 务执行的结果必须是使数据库从一个一致性状态变到另一个一致性状态。因此当数据库只包含成功事务提交的结果时,就说数据库处于一致性状态。如果数据库系统 运行中发生故障,有些事务尚未完成就被迫中断,这些未完成事务对数据库所做的修改有一部分已写入物理数据库,这时数据库就处于一种不正确的状态,或者说是 不一致的状态。
3 、隔离性
一个事务的执行不能其它事务干扰。即一个事务内部的操作及使用的数据对其它并发事务是隔离的,并发执行的各个事务之间不能互相干扰。
4 、持续性
也称永久性,指一个事务一旦提交,它对数据库中的数据的改变就应该是永久性的。接下来的其它操作或故障不应该对其执行结果有任何影响。
1 // --事务-- 提交按钮 2 protected void btn_Submit_Click(object sender, EventArgs e) 3 { 4 SqlConnection conn = CreateConnection(); 5 SqlCommand sqlCommand = new SqlCommand(); 6 conn.Open(); 7 //开始事务 8 SqlTransaction tran = conn.BeginTransaction(); 9 /*------把连接对象conn和事务对象tran赋给sqlCommand对象的连接属性、事务属性------*/ 10 sqlCommand.Connection = conn; 11 sqlCommand.Transaction = tran; 12 /*------------------------------------------------------------------------------*/ 13 try 14 { 15 sqlCommand.CommandText = "update student set Address=N'北京' where No=1"; //注意添 N ,否则显示‘??’ 16 sqlCommand.ExecuteNonQuery(); 17 sqlCommand.CommandText = "update student set Address=N'郑州' where No=2"; 18 sqlCommand.ExecuteNonQuery(); 19 //使用Commit()方法提交事务 20 tran.Commit(); 21 Label1.Text = "事务提交成功!"; 22 }catch(Exception ex) 23 { 24 tran.Rollback(); //-----回滚事务---- 25 Label1.Text = "事务提交失败:" + ex.Message; 26 } 27 finally 28 { 29 sqlCommand = null; 30 conn.Close(); 31 conn = null; 32 } 33 }