试想一下,如果并发的一个SQL,是通过主键索引来更新:update t1 set id = 100 where name = ‘d'; 此时,如果delete语句没有将主键索引上的记录加锁,那么并发的update...根据此图,可以看到,首先,id列索引上,满足id = 10查询条件的记录,均已加锁。同时,这些记录对应的主键索引上的记录也都加上了锁。...在这里,我直接给出分析后的结果:
Index key:pubtime > 1 and puptime 在idx_t1_pu索引上的查询范围。...针对Session 1,从name索引出发,读到的[hdc, 1],[hdc, 6]均满足条件,不仅会加name索引上的记录X锁,而且会加聚簇索引上的记录X锁,加锁顺序为先[1,hdc,100],后[6...而Session 2,从pubtime索引出发,[10,6],[100,1]均满足过滤条件,同样也会加聚簇索引上的记录X锁,加锁顺序为[6,hdc,10],后[1,hdc,100]。