MYSQL数据库Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读

MYSQL数据库Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读,第1张

概述介绍《MYSQL数据库Mysql InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读》开发教程,希望对您有用。

《MysqL数据库MysqL InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读》要点:
本文介绍了MysqL数据库MysqL InnoDB的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读,希望对您有用。如果有疑问,可以联系我们。

导读:MysqLInnoDB的事务隔离级别有四个:(默认是可重复读repeatable read)未提交读 read uncommit: 在另一个事务修改了数据,但尚未提交,...

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的四个事务隔离级别和(分别逐级解决的问题)脏读,不可重复读,虚读所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1161235.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存