ADO.NET事务处理

来源:互联网 发布:游戏编程精粹 pdf 云盘 编辑:程序博客网 时间:2024/06/08 11:30
 Ado.Net事务处理。
在ADO.NET 中,可以使用Connection 和Transaction 对象来控制事务。若要执行事务,请执行下列操作:
• 调用Connection 对象的BeginTransaction 方法来标记事务的开始。
• 将Transaction 对象分配给要执行的Command的Transaction 属性。
• 执行所需的命令。
• 调用Transaction 对象的Commit 方法来完成事务,或调用Rollback 方法来取消事务。
当然ADO.NET事务处理有优点和缺点,运用起来看具体情况了。
• 优点:
– 简单性
– 和数据据事务差不多的快
– 独立于数据库,不同数据库的专有代码被隐藏了
• 缺点:
– 事务不能跨越多个数据库连接
– 事务执行在数据库连接层上,所以需要在事务过程中维护一个数据库连接。

下边我们看一个例子,建立一个页面,同样简单,只需要一个按钮,然后编程:

 
 1using System; 2using System.Data; 3using System.Configuration; 4using System.Collections; 5using System.Web; 6using System.Web.Security; 7using System.Web.UI; 8using System.Web.UI.WebControls; 9using System.Web.UI.WebControls.WebParts;10using System.Web.UI.HtmlControls;11using System.Data.SqlClient;1213namespace WebApplication114{15    public partial class AdoAction : System.Web.UI.Page16    {17        protected void Page_Load(object sender, EventArgs e)18        {1920        }2122        protected void btn_Click(object sender, EventArgs e)23        {24            SqlConnection con= new SqlConnection();25            con.ConnectionString=ConfigurationManager.ConnectionStrings["DSN"].ConnectionString;26            con.Open();27            //启动一个事务。28            SqlTransaction myTran= con.BeginTransaction();29            //为事务创建一个命令,注意我们执行双条命令,第一次执行当然成功。我们再执行一次,失败。30            //第三次我们改其中一个命令,另一个不改,这时候事务会报错,这就是事务机制。31            SqlCommand myCom= new SqlCommand();32            myCom.Connection= con;33            myCom.Transaction= myTran;34            try35            {36                myCom.CommandText= "insert into SqlAction values ('测试2','111')";37                myCom.ExecuteNonQuery();38                myCom.CommandText= "insert into SqlAction values ('测试3','111')";39                myCom.ExecuteNonQuery();40                myTran.Commit();41                Response.Write("成功执行");4243            }44            catch (Exception Ex)45            {46                myTran.Rollback();47                //创建并且返回异常的错误信息48                Response.Write(Ex.ToString());49                Response.Write("写入数据库失败");50            }51            finally52            {53                con.Close();54            }55 56        }575859    }60} 

 

事务处理需要一个数据库连接以及一个事务处理对象。在SQL Server和ADO.NET中使用事务处理的难点在于SqlTransaction类。此类名称随所使用的数据库平台的不同而会有一些变化。例如,对于OLEDB数据库来说,事务处理类名为OleDbTransaction。

System.Data.SqlClient namespace包括了SqlTransaction类。此类包括了两个属性:

Connection:指示同事务处理相关联的SqlConnection对象;

IsolationLevel:定义事务处理的IsolationLevel。

属性IsolationLevel是包括如下成员的枚举对象:

Chaos:从高度独立的事务处理中出现的pending changes不能被覆盖;

ReadCommitted:当数据需要被非恶意读取时,采用共享锁定(shared locks),但数据仍然可以在事务处理结束时被更新,这造成了非重复性的数据读取(nonrepeatable reads)或phantom data的产生;

ReadUncommitted:恶意读取数据是可能发生的,这表示没有使用共享锁定(shared locks),并且没有实现独占锁定(exclusive locks);

RepeatableRead:锁定查询中所用到的所有数据,由此避免其他用户对数据进行更新。在phantom rows仍然可用的状态下,这可以避免非重复性的数据读取(nonrepeatable reads);

Serialisable:在DataSet中进行范围锁定,由此防止其他用户在事务处理结束之前更新数据或在数据库中插入行;

IsolationLevel定义锁定记录的级别,但这一概念不在本文论述范围之内。对象SqlTransaction也提供了类似的方法。你可以使用以下方法来进行事务处理:

Commit:提交数据库事务处理;

Rollback:从未决状态(pending state)反转(roll back)事务处理。事务处理一旦被提交后即不能执行此操作;

Save:在事务处理中创建savepoint可以对事务处理的一部分进行反转,并且指定savepoint名称。

以下的C#示例将这些部分综合起来。

这一简单的控制台程序将通过以下步骤将两行插入到Northwind数据库的表格中:

调用Connection对象的BeginTransaction方法以标记事务处理的起始位置。BeginTransaction方法对事务处理返回了一个坐标(reference),此坐标被指定给事务处理所用到的Command对象。

将Transaction对象指定给将要执行的Command的Transaction属性。如果某Command在活动Transaction中的Connection上被执行,并且Transaction对象还没有被指定到Command的Transaction属性,则会产生一个异常。

调用Transaction对象的Commit方法来结束事务处理,或者调用Rollback方法来取消事务处理。

等价的VB.NET代码与之类似。

事务处理结束

尽管这是一个简单的示例,但它还是充分显示了在.NET应用程序中使用事务处理是多么的简单。请记住,事务处理只有在处理一组命令时才是必要的。


在数据库连接上创建事务处理对象,然后调用事务处理对象来提交事务或回滚事务。简单的代码:

private void button1_Click(object sender, System.EventArgs e)  {   SqlConnection conn = new SqlConnection("Data Source=192.168.2.200;uid=sa; password=;database = HaierHR");   conn.Open();   //启用事务   SqlTransaction tran = conn.BeginTransaction();   SqlCommand cmd = new SqlCommand();   cmd.Connection = conn;   cmd.Transaction = tran;   try   {    cmd.CommandText = "UPDATE HRRollMain Set TotalMember=TotalMember-100 WHERE RollID = '2005070101'";    cmd.ExecuteNonQuery();    cmd.CommandText = "UPDATE HRRollSum Set TotalSumMember=TotalSumMember+100 WHERE RollSumID = '20050701'";    cmd.ExecuteNonQuery();    tran.Commit();    MessageBox.Show("事务提交成功!");   }   catch(Exception ex)   {    tran.Rollback();    MessageBox.Show("Error!"+ex.Message);   }      }