MySQL 幻象行

摘要:
假设表子级的ID列上有一个索引。您希望读取并锁定标识符值大于100的表中的所有行。查询从ID大于100的第一条记录开始,以扫描索引。如果在扫描范围内的索引记录上设置的锁没有锁定在间隙中(在本例中,间隙在90和102之间),InnoDB使用称为下一个密钥锁定的算法。当它搜索或扫描表索引时,它将对遇到的索引记录设置共享锁或独占锁。

当同一个查询在不同的时间产生不同的行集时,就会出现所谓的幻像问题。例如,如果执行了两次SELECT,但是第二次返回了第一次没有返回的行,那么该行就是一个“幻象”行。

假设在表child的id列上有一个索引,你想读取并锁定表中标识符值大于100的所有行,并打算稍后更新所选行的某些列:

SELECT * FROM child WHERE id > 100 FOR UPDATE;

该查询从id大于100的第一个记录开始扫描索引。假设表包含id值为90和102的行。如果在扫描范围内的索引记录上设置的锁没有锁定在间隙(在本例中是90到102之间的间隙),另一个会话可以向表中插入一个id为101的新行。如果要在同一个事务中执行相同的SELECT,则会在查询返回的结果集中看到一个id为101的新行(“幻象”)。这就违反了事务的隔离原则。

为了防止出现幻象,InnoDB使用了一种名为next-key锁定的算法,它结合了索引行锁和间隙锁。InnoDB执行行级锁的方式是这样的:当它搜索或扫描一个表索引时,它会在遇到的索引记录上设置共享锁或排他锁。因此,行级锁实际上是索引记录锁。此外,索引记录上的next-key锁也会影响该索引记录之前的“间隙”。也就是说,next-key锁是索引记录锁加上索引记录之前的间隙锁。如果一个会话在一个索引中的记录R上有一个共享锁或排他锁,另一个会话不能在紧接在索引顺序中的R之前的间隙中插入新的索引记录。

当InnoDB扫描一个索引时,它也可以锁定索引中最后一条记录之后的间隙。就像在前面的例子中发生的那样:为了防止插入id大于100的表,InnoDB设置的锁包括id值102后面的间隙锁。

MySQL 幻象行第1张

免责声明:文章转载自《MySQL 幻象行》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇【Ubuntu】Ubuntu常用文件操作命令linux和freebsd下的路由操作的区别下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

sql中自连接的使用

一、用SQL自连接查询处理列之间的关系 SQL自身连接,可以解决很多问题。下面举的一个例子,就是使用了SQL自身连接,它解决了列与列之间的逻辑关系问题,准确的讲是列与列之间的层次关系。SQL代码如下: 1 SELECT FIRST.CNumber, SECOND.PCNumber 2 FROM Course FIRST, Course SECOND 3 W...

mysql 统计行数count(*)

myIsam引擎把一个表的总行数存在了磁盘上,因此执行count(*)会直接返回结果,效率很高   #但是myisam不支持事物 innodb引擎需要把数据一行行从引擎里读出来,然后计数累加。 innodb由于多版本并发控制机制,同一时刻不同回话拿到的结果可能都不相同,所以不能直接将总行数存储在磁盘上。 比如同一时刻执行了三个会话 : A会话:  sele...

09mybatis属性和数据库字段不匹配处理

Book.java id name price book 表 book_id book_name book_price create table book( book_id int unsigned auto_increment, book_name varchar(20), book_price decimal(8,2), primary key(bo...

试试SQLServer 2014的内存优化表

试试SQLServer 2014的内存优化表 SQL Server2014存储引擎:行存储引擎,列存储引擎,内存引擎 SQL Server 2014中的内存引擎(代号为Hekaton)将OLTP提升到了新的高度。 现在,存储引擎已整合进当前的数据库管理系统,而使用先进内存技术来支持大规模OLTP工作负载。 就算如此,要利用此新功能,数据库必须包含“内存优化...

7、使用linux上的nacos

新建module   打开nacos   接着调用9001的controller方法: @RestController public class PaymentController { ​ @Value("${server.port}") private String serverPort; ​ @GetMapping(valu...

oracle高水位问题

转自:https://blog.csdn.net/cnham/article/details/5987999 说到HWM,我们首先要简要的谈谈ORACLE的逻辑存储管理.我们知道,ORACLE在逻辑存储上分4个粒度:表空间,段,区和块.    (1)块:是粒度最小的存储单位,现在标准的块大小是8K,ORACLE每一次I/O操作也是按块来操作的,也就是说当O...