可重复读隔离级别,不允许存在幻读,该隔离级别之所以能够有效防止幻读现象的出现,是因为可重复读这个隔离级别有用到GAP锁(间隙锁).下面我们以解析SQL语句为切入点,来解释个中原因. 前提条件:①数据库的存储引擎为InnoDB: ②数据库的隔离级别为“可重复读”. SQL:DELETE FROM user WHERE id = 10; (1)当id是聚簇索引或唯一索引时: 此时是没有使用到GAP锁的,但是也保证了幻读现象的出现. 原因:如果id是主键,那么主键必然是“唯一且不为空”的:如果id是唯