使用事务处理解决系统并发性操作

    对于一个应用软件系统,并发操作是一个不得不面对的难题,并发性对系统有极大的危害性,如果系统开发人员不能平衡这些并发请求,当同时执行这些操作时,可能造成数据的不一致,甚至造成系统的崩溃。

1、并发性

并发性是指两个或多个事件在同一时间间隔内发生。

2、事务

事务是SQL Server中的单个逻辑单元,一个事务内的所有语句被作为一个整体执行。

3、回滚

回滚简单的说就是泛指程序更新失败, 返回上一次正确状态的行为。

SQL Server中可以通过BEGIN TRANSACTION开始一个事务,提交事务可以使用COMMIT TRANSACTION 语句,回滚事务,可以执行ROLLBACK TRANSACTION 语句。

程序代码如下所示:

string strConn = "。。。。。";

        SqlConnection Conn = new SqlConnection(strConn);

        SqlTransaction myTran;

        SqlCommand cmd1, cmd2, cmd3;

        string strSql;

        Conn.Open();

        myTran = Conn.BeginTransaction();

        try

        {

           strSql = "INSERT INTO Customers(CustomerID,CompanyName)" +

                "VALUES('BDCOM','Baidu Comapny')";

            cmd1 = new SqlCommand(strSql, Conn);

            cmd1.Transaction = myTran;

            cmd1.ExecuteNonQuery();           

            strSql = "INSERT INTO Orders(CustomerID) VALUES('BDCOM')";

            cmd2 = new SqlCommand(strSql, Conn);

            cmd2.Transaction = myTran;

            cmd2.ExecuteNonQuery();

            myTran.Commit();

          }

        catch

        {

            myTran.Rollback();      

        }

        finally

        {

            Conn.Close();

        }

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值