一般会使用事务的隔离级别来处理并发问题,而oracle中只支持两种:
ReadCommitted :读已提交,事务执行过程中可以读取其他事务cmmitd的数据。
Serializable:事务按顺序执行,完全解决并发中的脏读、不可重复读、幻读问题。
按照EF中的说明,Serializable隔离级别可以使当前事务查询、修改的数据被锁住,其他任何用户不可以修改,直到本事务结束。
然而,测试中发现,事务执行过程中,两次读取同一个表数据时,在第一次读取后,通过plsql对数据进行修改,可以成功,且第二次读取后,和第一次数据相同。
如图:
第一次执行sql:
此时通过plsql修改数据
第二次执行sql:
是否说明EF中的Serializable隔离级别和oracle的解释不相同呢,只是在事务开始前将所用到的数据保存副本,保证事务过程中数据一致?