帮忙么网 > MySQL > 当前页面

什么是脏读、幻读、不可重复读的?

2025-01-10 NEW个对象

脏读:读到其它事务没有提交的数据
不可重复读:能够读到其它事务已经提交的数据,在事务第二次读取数据的时候,前后不一致。
脏读:当一个事务insert数据之后,当前事务读取的条数不一致

如何解决脏读、幻读、不可重复读的?

Innodb主要通过mvcc机制和间隙锁来解决的

脏读:设置隔离级别读已提交,事务只能读取到事务已经提交的数据。

在读已提交隔离级别下,innodb获取的是最新的事务id,从而获取到最新的提价数据。

不可重复读:设置隔离级别可重复读。

可重复读事务开启前后,事务id是一样的,所以获取的数据是一样的。

幻读:设置隔离级别可串行化。

可以彻底解决幻读问题,但是性能很差,因为读写都要加锁。

相关文章

  • 聚簇索引与非聚簇索引的区别

    聚簇索引:将数据存储与索引放到了一块,索引结构的叶子节点保存了行数据。 非聚簇索引:将数据与索引分开存储,索引结构的叶子节点指向了数据对应的位置。

    NEW个对象 2024-12-25

  • SQL基础知识

    SQL基础知识

    NEW个对象 2025-01-13

  • 什么是脏读、幻读、不可重复读的?

    脏读:读到其它事务没有提交的数据 不可重复读:能够读到其它事务已经提交的数据,在事务第二次读取数据的时候,前后不一致。 脏读:当一个事务insert数据之后,当前事务读取的条数不一致

    NEW个对象 2025-01-10

推荐文章