WebForm中C#事务回滚的例子

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

namespace snc
{
///
/// testdb 的摘要说明。
///
public class testdb : System.Web.UI.Page
{
private void Page_Load(object sender, System.EventArgs e)
{
// 在此处放置用户代码以初始化页面
this.DoTran();
Response.Write("提示信息,事务处理完毕!");

}

#region Web 窗体设计器生成的代码
override protected void OnInit(EventArgs e)
{
//
// CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
//
InitializeComponent();
base.OnInit(e);
}

///
/// 设计器支持所需的方法 - 不要使用代码编辑器修改
/// 此方法的内容。
///
private void InitializeComponent()
{
this.Load += new System.EventHandler(this.Page_Load);
}
#endregion
private SqlConnection GetConn()
   {
   string strSql="server=localhost;database=ljt_sg;User Id=sa;pwd=100369;Enlist=true;Pooling=true;Max Pool Size=1000;Min Pool Size=0;Connection Lifetime=300;packet size=1000";
   SqlConnection myConn=new SqlConnection(strSql);
   return myConn;
   }
public void DoTran()
   {
SqlConnection myConn=GetConn();
myConn.Open();
SqlCommand myComm=new SqlCommand();
SqlTransaction myTran;
myTran=myConn.BeginTransaction();
myComm.Connection=myConn;
myComm.Transaction=myTran;
try
{
myComm.CommandText="USE ljt_sg";
myComm.ExecuteNonQuery();
myComm.CommandText="UPDATE hy_wh SET password = '444'";
myComm.ExecuteNonQuery();
//myComm.CommandText="Create database testdb";
//myComm.ExecuteNonQuery();
myComm.CommandText="UPDATE hy_wh set zyx2 = '555' wr";
myComm.ExecuteNonQuery();
myTran.Commit();
}
catch(Exception err)
{
myTran.Rollback();
Response.Write("事务操作出错,已回滚。系统信息:"+err.Message);
}
}
}
}

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/631872/viewspace-863271/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/631872/viewspace-863271/

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值