EF6 中 事务隔离级别为IsolationLevel.Serializable不起作用???

一般会使用事务的隔离级别来处理并发问题,而oracle中只支持两种:

ReadCommitted :读已提交,事务执行过程中可以读取其他事务cmmitd的数据。

Serializable:事务按顺序执行,完全解决并发中的脏读、不可重复读、幻读问题。

按照EF中的说明,Serializable隔离级别可以使当前事务查询、修改的数据被锁住,其他任何用户不可以修改,直到本事务结束。

然而,测试中发现,事务执行过程中,两次读取同一个表数据时,在第一次读取后,通过plsql对数据进行修改,可以成功,且第二次读取后,和第一次数据相同。

如图:

第一次执行sql:

此时通过plsql修改数据

第二次执行sql:

是否说明EF中的Serializable隔离级别和oracle的解释不相同呢,只是在事务开始前将所用到的数据保存副本,保证事务过程中数据一致?

转载于:https://my.oschina.net/dyc1122/blog/893067

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值