全县网站建设管理工作会议召开,美发培训职业学校,网站建设者,老网站301跳转新网站上一讲我们给大家讲解了不可重复读这个问题#xff0c;这个问题简单来说#xff0c;就是一个事务多次查询一条数据#xff0c;结果每次读到的值都不一样#xff0c;这个过程中可能别的事务会修改这条数据的值#xff0c;而且修改值之后事务都提交了#xff0c;结果导致人…上一讲我们给大家讲解了不可重复读这个问题这个问题简单来说就是一个事务多次查询一条数据结果每次读到的值都不一样这个过程中可能别的事务会修改这条数据的值而且修改值之后事务都提交了结果导致人家每次查到的值都不一样都查到了提交事务修改过的值这就是所谓的不可重复读。
不可重复读就是一条数据的值没法满足多次重复读值都一样别的事务修改了值提交之后就不可重复读了说着有点拗口不过相信大家应该反复看两遍应该都能理解
包括之前的脏写和脏读其实也都分别代表了不同的数据库的问题脏写就是两个事务没提交的状况下都修改同一条数据结果一个事务回滚了把另外一个事务修改的值也给撤销了所谓脏写就是两个事务没提交状态下修改同一个值。
脏读就是一个事务修改了一条数据的值结果还没提交呢另外一个事务就读到了你修改的值然后你回滚了人家事务再次读就读不到了也就是说人家事务读到了你修改之后还没提交的值这就是脏读了。
而不可重复读针对的是已经提交的事务修改的值被你事务给读到了你事务内多次查询多次读到的是别的已经提交的事务修改过的值这就导致不可重复读了。
这个数据库的多种并发问题确实很拗口需要大家好好理解。
今天我们来最后讲一种数据库的并发问题就是听着有点恐怖的幻读问题
简单来说你一个事务A先发送一条SQL语句里面有一个条件要查询一批数据出来比如“select * from table where id10”类似这种SQL
然后呢他一开始查询出来了10条数据如下图所示。 接着这个时候别的事务B往表里插入了几条数据而且事务B还提交了如下图所示此时多了几行数据出来。 接着事务A此时第三次查询再次按照之前的一模一样的条件执行“select * from table where id10”这条SQL语句由于其他事务插入了几条数据导致这次他查询出来了12条数据如下图所示。 于是此时事务A开始怀疑自己的双眼了为什么一模一样的SQL语句第一次查询是10条数据第二次查询是12条数据难道刚才出现了幻觉导致我刚才幻读了这就是幻读这个名词的由来。
幻读指的就是你一个事务用一样的SQL多次查询结果每次查询都会发现查到了一些之前没看到过的数据
注意幻读特指的是你查询到了之前查询没看到过的数据此时就说你是幻读了。
说实在的大家看完最近几篇文章应该都有一个感觉就是脏写、脏读、不可重复读、幻读都是因为业务系统会多线程并发执行每个线程可能都会开启一个事务每个事务都会执行增删改查操作。
然后数据库会并发执行多个事务多个事务可能会并发的对缓存页里的同一批数据进行增删改查操作于是这个并发增删改查同一批数据的问题可能就会导致我们说的脏写、脏读、不可重复读、幻读这些问题。
所以这些问题的本质都是数据库的多事务并发问题那么为了解决多事务并发问题数据库才设计了事务隔离机制、MVCC多版本隔离机制、锁机制用一整套机制来解决多事务并发问题接下来我们将要深入讲解这些机制让大家彻底能够理解数据库内部的执行原理。
深刻理解了原理之后后续我们讲解各种数据库优化实践案例大家才能深刻理解就跟我之前的《从0开始带你成为JVM实战高手》一样先得透彻理解了JVM运行的工作原理才能理解如何对JVM进行实战优化。
只不过JVM的内部运行原理比数据库而言相对内容少一些所以当时很快就进入了大量的实践案例阶段而数据库的话内部原理会更加复杂一些所以耗费的时间会多一些。