物流网站建设实例,微信分销app,免费游戏源码网,wordpress传到主机网络上关于这方面的博文有些偏理论#xff0c;有些通篇代码#xff0c;都不能深入浅出。本文用图文并茂的方式#xff0c;配上行云流水般的代码#xff0c;非要摆清楚这个问题。相关代码已提交至码云#xff08;点击这里下载#xff09;。事务是现代关系型数据库的核心之… 网络上关于这方面的博文有些偏理论有些通篇代码都不能深入浅出。本文用图文并茂的方式配上行云流水般的代码非要摆清楚这个问题。相关代码已提交至码云点击这里下载。事务是现代关系型数据库的核心之一。在多个事务并发操作数据库多线程、网络并发等的时候如果没有有效的避免机制就会出现以下几种问题第一类丢失更新Lost Update在完全未隔离事务的情况下两个事务更新同一条数据资源某一事务完成另一事务异常终止回滚造成第一个完成的更新也同时丢失 。这个问题现代关系型数据库已经不会发生就不在这里占用篇幅有兴趣的可以自行百度。脏读Dirty ReadA事务执行过程中B事务读取了A事务的修改。但是由于某些原因A事务可能没有完成提交发生RollBack了操作则B事务所读取的数据就会是不正确的。这个未提交数据就是脏读Dirty Read。脏读产生的流程如下可以用EF Core模拟此过程对应的执行结果不可重复读Nonrepeatable ReadB事务读取了两次数据在这两次的读取过程中A事务修改了数据B事务的这两次读取出来的数据不一样。B事务这种读取的结果即为不可重复读Nonrepeatable Read。不可重复读的产生的流程如下模拟代码如下脏读示例对应的执行结果不可重复读有一种特殊情况两个事务更新同一条数据资源后完成的事务会造成先完成的事务更新丢失。这种情况就是大名鼎鼎的第二类丢失更新。主流的数据库已经默认屏蔽了第一类丢失更新问题即后做的事务撤销发生回滚造成已完成事务的更新丢失但我们编程的时候仍需要特别注意第二类丢失更新。它产生的流程如下模拟代码如下对应的执行结果不可重复读有一种特殊情况两个事务更新同一条数据资源后完成的事务会造成先完成的事务更新丢失。这种情况就是大名鼎鼎的第二类丢失更新。主流的数据库已经默认屏蔽了第一类丢失更新问题即后做的事务撤销发生回滚造成已完成事务的更新丢失但我们编程的时候仍需要特别注意第二类丢失更新。它产生的流程如下模拟代码如下对应的执行结果如下图可以明显看出事务A的更新被事务B所覆盖更新丢失。幻读Phantom ReadB事务读取了两次数据在这两次的读取过程中A事务添加了数据B事务的这两次读取出来的集合不一样。幻读产生的流程如下这个流程看起来和不可重复读差不多但幻读强调的集合的增减而不是单独一条数据的修改。模拟代码如下执行结果数据库隔离级别为了解决上面提及的并发问题主流关系型数据库都会提供四种事务隔离级别。读未提交Read Uncommitted在该隔离级别所有事务都可以看到其他未提交事务的执行结果。本隔离级别是最低的隔离级别虽然拥有超高的并发处理能力及很低的系统开销但很少用于实际应用。因为采用这种隔离级别只能防止第一类更新丢失问题不能解决脏读不可重复读及幻读问题。读已提交Read Committed这是大多数数据库系统的默认隔离级别但不是MySQL默认的。它满足了隔离的简单定义一个事务只能看见已经提交事务所做的改变。这种隔离级别可以防止脏读问题但会出现不可重复读及幻读问题。可重复读Repeatable Read这是MySQL的默认事务隔离级别它确保同一事务的多个实例在并发读取数据时会看到同样的数据行。这种隔离级别可以防止除幻读外的其他问题。可串行化Serializable这是最高的隔离级别它通过强制事务排序使之不可能相互冲突从而解决幻读、第二类更新丢失问题。在这个级别可以解决上面提到的所有并发问题但可能导致大量的超时现象和锁竞争通常数据库不会用这个隔离级别我们需要其他的机制来解决这些问题:乐观锁和悲观锁。这四种隔离级别会产生的问题如下网上到处都有懒得画了如何使用数据库的隔离级别很多文章博客在介绍完这些隔离级别以后就没有以后了。读的人一般会觉得嗯是这么回事我知道了学习一个知识点是需要实践的。比如下面这个常见而又异常严重的情况图中是典型的第二类丢失更新问题后果异常严重。我们这里就以读已提交Read Committed及以下隔离级别中会出现不可重复读现象为例。从上面的表格可以看出当事务隔离级别为可重复读Repeatable Read时可以避免。把TestReadCommitted中的Read线程事务级别调整一下这时执行效果如下实际项目中通过提示客户端重做的方式完美解决了不可重复读的问题。其他并发问题也可以通过类似的方式解决。最后文中提到可串行化解决幻读的问题会在下篇文章详细介绍包含各种酷炫的乐观锁操作敬请期待 原文地址https://www.cnblogs.com/yubaolee/p/10398633.html.NET社区新闻深度好文欢迎访问公众号文章汇总 http://www.csharpkit.com