SQL事务处理

来源:互联网 发布:流程图软件有哪些 编辑:程序博客网 时间:2024/05/22 16:44

第一种:
set   xact_abort   on
begin   tran
        insert   ...
        update   ...
        delete   ...
commit   tran

第二种:
set   xact_abort   on
begin   tran
        insert   ...
        if @@error<>0 rollback tran
        update   ... 
        if @@error<>0 rollback tran
        delete   ...
        if @@error<>0 rollback tran
commit   tran

第三种:
set   xact_abort   on
begin   tran
        insert   ...
        update   ... 
        delete   ...

if @@error<>0
rollback  tran
else
commit   tran


第四种:
set   xact_abort   on
begin   tran
declare @ErrorSave int
        insert   ...
        if @@error<>0  set  @ErrorSave=1
        update   ... 
      if @@error<>0  set  @ErrorSave=1
        delete   ...
      if @@error<>0  set  @ErrorSave=1

if @ErrorSave>0
rollback  tran
else
commit   tran

使用事务的缺陷:使用多了事务处理,经常会产生死锁现象,特别是多用户并发插入修改删除数据的时候,会造成服务器运行缓慢.所以有时候只好采取删除掉事务的代码,而是提前在程序中检测输入的存储过程参数是否合法数据.

 

//执行事务处理
public void DoTran()
{  //建立连接并打开
 SqlConnection myConn=GetConn();
 myConn.Open();
 SqlCommand myComm
=new SqlCommand();
 
//SqlTransaction myTran=new SqlTransaction();
 
//注意,SqlTransaction类无公开的构造函数
 SqlTransaction myTran;
 
//创建一个事务
 myTran=myConn.BeginTransaction();
 
try
 
{
  
//从此开始,基于该连接的数据操作都被认为是事务的一部分
  
//下面绑定连接和事务对象
  myComm.Connection=myConn;
  myComm.Transaction
=myTran; //定位到pubs数据库
  myComm.CommandText="USE pubs";
  myComm.ExecuteNonQuery();
//更新数据
  
//将所有的计算机类图书
  myComm.CommandText="UPDATE roysched SET royalty = royalty * 1.10 WHERE title_id LIKE 'Pc%'";
  myComm.ExecuteNonQuery();
   
//提交事务
  myTran.Commit();
 }

 
catch(Exception err)
 
{
  
throw new ApplicationException("事务操作出错,系统信息:"+err.Message);
  }

 
finally
 
{
  myConn.Close();
  }

}


 
private SqlConnection GetConn()
  
{
   
string strSql="Data Source=localhost;Integrated Security=SSPI;user id=sa;password=";
   SqlConnection myConn
=new SqlConnection(strSql);
   
return myConn;
  }

 }
 
public class Test
 
{
  
public static void Main()
  
{
   DbTranSql tranTest
=new DbTranSql();
   tranTest.DoTran();
   Console.WriteLine(
"事务处理已经成功完成。");
   Console.ReadLine();
  }

 }
 

原创粉丝点击