WebForm中C#事務回滾的例子

hljhrbsjf發表於2006-09-05

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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章