vb.net mysql 事务_Ado.Net事务处理。

在ADO.NET 中,可以使用Connection 和Transaction 对象来控制事务。若要执行事务,请执行下列操作:

• 调用Connection 对象的BeginTransaction 方法来标记事务的开始。

• 将Transaction 对象分配给要执行的Command的Transaction 属性。

• 执行所需的命令。

• 调用Transaction 对象的Commit 方法来完成事务,或调用Rollback 方法来取消事务。

当然ADO.NET事务处理有优点和缺点,运用起来看具体情况了。

• 优点:

– 简单性

– 和数据据事务差不多的快

– 独立于数据库,不同数据库的专有代码被隐藏了

• 缺点:

– 事务不能跨越多个数据库连接

– 事务执行在数据库连接层上,所以需要在事务过程中维护一个数据库连接。

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

1usingSystem;2usingSystem.Data;3usingSystem.Configuration;4usingSystem.Collections;5usingSystem.Web;6usingSystem.Web.Security;7usingSystem.Web.UI;8usingSystem.Web.UI.WebControls;9usingSystem.Web.UI.WebControls.WebParts;10usingSystem.Web.UI.HtmlControls;11usingSystem.Data.SqlClient;1213namespaceWebApplication114{15publicpartialclassAdoAction : System.Web.UI.Page16{17protectedvoidPage_Load(objectsender, EventArgs e)18{1920}2122protectedvoidbtn_Click(objectsender, EventArgs e)23{24SqlConnection con=newSqlConnection();25con.ConnectionString=ConfigurationManager.ConnectionStrings["DSN"].ConnectionString;26con.Open();27//启动一个事务。28SqlTransaction myTran=con.BeginTransaction();29//为事务创建一个命令,注意我们执行双条命令,第一次执行当然成功。我们再执行一次,失败。30//第三次我们改其中一个命令,另一个不改,这时候事务会报错,这就是事务机制。31SqlCommand myCom=newSqlCommand();32myCom.Connection=con;33myCom.Transaction=myTran;34try35{36myCom.CommandText="insert into SqlAction values ('测试2','111')";37myCom.ExecuteNonQuery();38myCom.CommandText="insert into SqlAction values ('测试3','111')";39myCom.ExecuteNonQuery();40myTran.Commit();41Response.Write("成功执行");4243}44catch(Exception Ex)45{46myTran.Rollback();47//创建并且返回异常的错误信息48Response.Write(Ex.ToString());49Response.Write("写入数据库失败");50}51finally52{53con.Close();54}5556}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应用程序中使用事务处理是多么的简单。请记住,事务处理只有在处理一组命令时才是必要的。

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

731655954c7be9d8835ece551b5385f8.pngprivatevoidbutton1_Click(objectsender, System.EventArgs e)

24a924a57ba6b3f2b51fc9edb7ea4186.png{

1408c5260b2f05e450dee929db9be5f7.png   SqlConnection conn=newSqlConnection("Data Source=192.168.2.200;uid=sa; password=;database = HaierHR");

1408c5260b2f05e450dee929db9be5f7.png   conn.Open();

1408c5260b2f05e450dee929db9be5f7.png//启用事务1408c5260b2f05e450dee929db9be5f7.pngSqlTransaction tran=conn.BeginTransaction();

1408c5260b2f05e450dee929db9be5f7.png   SqlCommand cmd=newSqlCommand();

1408c5260b2f05e450dee929db9be5f7.png   cmd.Connection=conn;

1408c5260b2f05e450dee929db9be5f7.png   cmd.Transaction=tran;

1408c5260b2f05e450dee929db9be5f7.pngtry715f2d05503b99d41f3b6ba2cdccc84d.png{

1408c5260b2f05e450dee929db9be5f7.png    cmd.CommandText="UPDATE HRRollMain Set TotalMember=TotalMember-100 WHERE RollID = '2005070101'";

1408c5260b2f05e450dee929db9be5f7.png    cmd.ExecuteNonQuery();

1408c5260b2f05e450dee929db9be5f7.png    cmd.CommandText="UPDATE HRRollSum Set TotalSumMember=TotalSumMember+100 WHERE RollSumID = '20050701'";

1408c5260b2f05e450dee929db9be5f7.png    cmd.ExecuteNonQuery();

1408c5260b2f05e450dee929db9be5f7.png    tran.Commit();

1408c5260b2f05e450dee929db9be5f7.png    MessageBox.Show("事务提交成功!");

5bcb1807ee3e00d2b3c225f0b3f5c751.png   }1408c5260b2f05e450dee929db9be5f7.pngcatch(Exception ex)

715f2d05503b99d41f3b6ba2cdccc84d.png{

1408c5260b2f05e450dee929db9be5f7.png    tran.Rollback();

1408c5260b2f05e450dee929db9be5f7.png    MessageBox.Show("Error!"+ex.Message);

5bcb1807ee3e00d2b3c225f0b3f5c751.png   }f466905a3bcb5dcef110eab799825254.png  }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值