《MysqL数据库MysqL InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读》要点:
本文介绍了MysqL数据库MysqL InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读,希望对您有用。如果有疑问,可以联系我们。
MysqL必读MysqLInnoDB的事务隔离级别有四个:(默认是可重复读repeatable read)
MysqL必读未提交读 read uncommit : 在另一个事务修改了数据,在本事务中SELECT语句可能会查询到这些未被提交的数据,而发生脏读.
MysqL必读提交读 read commit : 在一个事务中发生两次SELECT查询,当第一次SELECT执行完查询到一些数据,接下来另一个事务修改了这些数据并提交了,当第二次SELECT执行的时候查询到的数据和第一次SELECT的不同,而发生不可重复读、幻读问题,但解决了脏读(锁定所读取的当前行).
MysqL必读可重复读 repeatable read:在同一个事务中,SELECT的结果是事务开启时时间点的结果,因此,同样的SELECT查询的结果总是一致的.解决了不可重复读,但有可能发生虚读(锁定所读取的所有行).
MysqL必读串行化 serializable:
MysqL必读(转载的)
MysqL必读 1). 脏读
MysqL必读 首先区分脏页和脏数据
MysqL必读 脏页是内存的缓冲池中已经修改的page,未及时flush到硬盘,但已经写到redo log中.读取和修改缓冲池的page很正常,可以提高效率,flush即可同步.脏数据是指事务对缓冲池中的行记录record进行了修改,但是还没提交!!!,如果这时读取缓冲池中未提交的行数据就叫脏读,违反了事务的隔离性.脏读就是指当一个事务正在访问数据,并且对数据进行了修改,而这种修改还没有提交到数据库中,这时,另外一个事务也访问这个数据,然后使用了这个数据.
MysqL必读 2). 不可重复读
MysqL必读 是指在一个事务内,多次读同一数据.在这个事务还没有结束时,另外一个事务也访问该同一数据.那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,第二个事务已经提交.那么第一个事务两次读到的的数据可能是不一样的.这样就发生了在一个事务内两次读到的数据是不一样的,因此称为是不可重复读.例如,一个编辑人员两次读取同一文档,但在两次读取之间,作者重写了该文档.当编辑人员第二次读取文档时,文档已更改.原始读取不可重复.如果只有在作者全部完成编写后编辑人员才可以读取文档,则可以避免该问题
MysqL必读 3). 虚读 :
MysqL必读 是指当事务不是独立执行时发生的一种现象,例如第一个事务对一个表中的数据进行了修改,这种修改涉及到表中的全部数据行.同时,第二个事务也修改这个表中的数据,这种修改是向表中插入一行新数据.那么,以后就会发生 *** 作第一个事务的用户发现表中还有没有修改的数据行,就好象发生了幻觉一样.例如,一个编辑人员更改作者提交的文档,但当生产部门将其更改内容合并到该文档的主复本时,发现作者已将未编辑的新材料添加到该文档中.如果在编辑人员和生产部门完成对原始文档的处理之前,任何人都不能将新材料添加到文档中,则可以避免该问题.
事务A | connection.setautoCommit(false) | start Transaction | MysqL必读update student set money=money+100 MysqL必读from account MysqL必读where name='a' | commit(); | insert into account (name,money)values('fff',10000); | ||
(事务B) | MysqL必读select money from account where name='a'; MysqL必读发现有1000块 | MysqL必读 MysqL必读 MysqL必读 | MysqL必读select money from account where name='a'; MysqL必读发现有1100 | MysqL必读select money from account where name='a'; MysqL必读发现有1100 | select * from account (查询结果包含fff的信息) | commit(); | |
说明 | 事务B读到了事务A未提交的数据,发生了脏读 | 事务A提交后,事务B前后SELECT查询money的值不一致,即事务B读到了事务A,update后的数据,发生了不可重复读 | 虚读(即一个事务读到了另一个事务insert的数据) | 可设置的事务级别 | read commit | repeatable read |
总结
以上是内存溢出为你收集整理的MYSQL数据库Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读全部内容,希望文章能够帮你解决MYSQL数据库Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)