jin__8000608172 2016-11-02 01:08 采纳率: 0%
浏览 835
已结题

关于.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();
}

二、运行环境

Windows2008 + .net Framework3.5 + SqServer2008R2,web服务器和Db服务器是分开的

三、问题现象

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

四、问题来了

1、这是什么原因呢?
2、除了提高事务的隔离级别,还有别的办法吗?

  • 写回答

1条回答 默认 最新

  • oyljerry 2016-11-02 04:59
    关注

    你的改动有生效吗,不然你怎么衡量回滚有没有发生

    评论

报告相同问题?

悬赏问题

  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码
  • ¥15 matlab代码解决,怎么运行