InnoDB可重复读能不能解决幻读问题?
第一种解释:不能
事务A一开始select出3条记录,ID分别是1/2/3,然后尝试插入ID为4的记录。此时正好事务B已经插入了ID为4的记录,并且提交。那么事务A的插入操作会失败,因为事务A已经读了事务B插入的ID为4的记录。这就是幻读。
第二种解析:能
InnoDB会加Netx-Key Lock,包括行锁(Record Lock)和间隙锁(Gap Lock)。间隙锁会锁住后面没有的记录,可以用来解决幻读的问题。比如事务A一开始使用select ... for update读出3条记录,此时由于间隙锁的存在,ID大于3的记录(不存在)将被锁住,那么事务B将不能插入ID为4的记录,所以就不存在幻读的问题。