事务处理

事务处理的过程
  开始事务,进入事务待命状态--〉记录要改改变的记录,对要改变的记录加锁--〉拷贝加锁的记录--〉
            事务更新--〉释放记录锁,抛弃事务日志和备份的记录
事务处理方法:
 1)利用数据库处理(例如在存储过程里面)
   好处:速度快
   例如:
   Create Pro SqlTran As
    begin tran
    declare @errorinfo int
    //sql语句
    select @errorinfo=@@error
    if(@errorinfo=0)
      commit tran
    else
     rollback tran
   go     
 2)在代码里面加入事务处理
   好处:独立于数据库
   private void Tran(string strconn)
   {
      SqlConnection conn=new SqlConnection(strconn);
      conn.Open();
      //启动事务
      SqlTransaction tran=conn.BeginTransaction();
      //为事务创建命令
      SqlCommand cmd=new SqlCommand();
      cmd.Connection=conn;
      cmd.Transaction=tran;
      try
      {
        cmd.CommandText=//sql语句
        cmd.ExecuteNonQuery();
        tran.Commit();
      }
      catch()
      {
         tran.Rollback();
        
      }
      finally
      {
         conn.Close();
      }
   }
 3)利用COM+来进行事务处理
   好处:实现对不同数据库的操作
   //建一个类库
   //using Syatem.EnterpriseService
   //Required:假如事务存在则共享事务,否则创建新事务
   [Transaction(TransactionOption.Required,timeout=1200)]
   public class ES:ServiceComponet
   {
      public void db(string username)
      {
        try
        {
         strsql="delete from user where username='"+username+"'";
          SqlConnection conn=new SqlConnection(strconn);
          conn.Open();
          SqlCommand cmd=new SqlCommand(strsql);
          cmd.ExecuteNonQuery();
          ContextUtil.SetComplete();
          conn.Close();
        }
        catch
        {
          ContextUtil.SetAbort();
        }
      }
   }
   对类ES必须要有一个强名称进行签名,sn.exe -k a.snk,然后将密钥文件拷入项目中
   在AssemblyInfo.vc中加入密钥 [assembly:AssemblyKeyFileAttribute["..//..//a.snk"]]
   使用regsvcs.exe 将Dll注册到Com+ Services里面
   使用上面的类
   private void DelUser()
   {
      ES es=new Es();
      try
      {
        es.db("prolove");
      }
      catch
      {
      }
   } 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值