• 处理事务的两种方式


      当要对两张表同时进行操作时,我们通常都要使用事务,避免在操作的过程中产生异常,而导致结果的不正确,我们可以在数据库中定义事务的处理,也可以利用asp.net的事务处理类来操作事务。具体这两张方法的使用,请看下面的介绍:

    1.在数据库中进行处理,主要使用begin transaction,commit transaction,rollback transaction三个操作来实现,另外通过借助@@ERROR函数获取sql语句执行过程中是否发生了错误。

    declare @error int
    begin transaction
    update AccountOfBank
    set balance=balance+5000 where accountName='张三'
    set @error=@error+@@ERROR
    update AccountOfBank
    set balance=balance-5000 where accountName='李四'
    set @error=@error+@@ERROR
    if(@error<>0)
    rollback transaction
    else
    commit transaction

    2.使用asp.net的事务处理类来操作

      

    SqlConnection con = new SqlConnection("server=.;database=Test;uid=sa;pwd=123456");
    con.Open();
    SqlTransaction tran
    = con.BeginTransaction();
    SqlCommand cmd
    = new SqlCommand();
    cmd.Connection
    = con;
    cmd.Transaction
    = tran;
    try
    {
    cmd.CommandText
    = "update AccountOfBank set balance=balance-5000 where accountName='张三'";
    cmd.ExecuteNonQuery();
    cmd.CommandText
    = "update AccountOfBank set balance=balance+5000 where accountName='李四'";
    cmd.ExecuteNonQuery();
    tran.Commit();
    }
    catch (Exception)
    {
    tran.Rollback();
    }
    finally
    {
    con.Close();
    }
  • 相关阅读:
    Mysql的表名/字段名/字段值是否区分大小写
    20个PHP程序性能优化的方法
    PHP中大括号用法
    PHP伪类型和伪变量
    PHP中关于取模运算及符号
    PHP之array_flip()方法
    PHP之implode()方法
    PHP中is_null()方法
    原型模式(Prototype)
    适配器模式
  • 原文地址:https://www.cnblogs.com/hnsdwhl/p/1936428.html
Copyright © 2020-2023  润新知