NoReady
NoReady
2016-11-01 22:22
采纳率: 0%
浏览 965

.net 事务的隔离级别,事务为什么事实上没有遵循原子性?

示意代码如下:

             TransactionOptions transOption = new TransactionOptions();
            transOption.IsolationLevel = System.Transactions.IsolationLevel.RepeatableRead;
            using (TransactionScope ts = new TransactionScope(TransactionScopeOption.RequiresNew, transOption))
            {
                //1、增加申请
                dal.Add(apply);

                //2、更新订单状态
                dalOrders.UpdateStatus(orderId, PaymentStatus.等待退款.GetHashCode());

                //提交事务
                ts.Complete();
            }

现在我遇到的奇怪现象是,在数据库压力大的情况下,有万分之一概率出现:事务提交了,但第2步实际上失败了(数据没有更新)。

我的线上环境是:
Windows2008 + .net Framework3.5 + SqServer2008R2,web服务器和Db服务器是分开的。

有谁遇到过这样的情况吗:
1、这是什么原因呢?
2、除了提高事务的隔离级别,还有别的办法吗?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

1条回答 默认 最新

  • NoReady
    NoReady 2016-11-01 22:24

    1)问题现象
    第1步成功了,第2步失败了,但事务没有回滚而是提交了。

    2)我的运行环境
    Windows2008 + .net Framework3.5 + SqServer2008R2,web服务器和Db服务器是分开的

    点赞 评论

相关推荐