asp.net mysql 事务_asp.net 数据库连接 使用事务处理(一)

在.net中,事务处理机制共有四种:数据库事务;ADO.NET事务;ASP.NET事务;企业服务及事务。

ASP.NET事务是在Web应用程序的页面层工作,只需简单的在页面属性中加一个"Transaction="Required"",这样页面中的时间处理都作为页面整个事务的 一部分,该页面的任何处理出现问题,所以的处理都会回滚。

为了执行一个ADO.NET事务,首先需要创建一个SqlTransaction对象,可以调用SqlConnection对象的BeginTransaction()方法来创建SqlTransaction对象。然后把它赋给SqlCommand对象的事务属性。当事务开始后,就可以执行任意次数的SqlCommand动作,但要保证SqlCommand对象属于同一个事务和连接。执行成功后,使用SqlTransaction的Commit()方法提交事务,否则使用SqlTransaction的Rollback()方法回滚事务。

实例代码如下:

SqlTransaction tran=null;

using(SqlConnection cnn=new SqlConnection(连接路径))

{

try

{

cnn.open();

//调用SqlConnection的BeginTransaction方法开启一个事务

//并返回已经开启的事务

tran=cnn.BeginTransaction();

SqlCommand cmd=new SqlCommand();

cmd.Transaction=tran;

//...数据库访问代码

tran.Commit();

}

catch(Exception ex)

{

tran.RollBack();

}

finally{cnn.close();}

}

也可以使用TransactionOptions配置事务设置

在使用TransactionOptions时要先引用System.Transactions。

实例代码:

TransactionOptions opt = new TransactionOptions();

opt.IsolationLevel = System.Transactions.IsolationLevel.Serializable;

using (CommittableTransaction tran = new CommittableTransaction(opt))

{

try

{

//几个要绑定成同一个事务处理方法

tran.Commit();

}

catch(Exception ex)

{

tran.RollBack();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值