361
1、插入意向锁是Gap锁,不是意向锁,是insert操作产生的。当多个事务同时将不同的数据写入同一个索引间隙时,不需要等待其他事务完成,也不会发生锁等待。
假定有一个记录索引包含键值4和7,不同的事务分别插入5和6,每个事务都会产生一个插入意向锁,加到4-7之间,得到插入行上的排他锁,但不会相互锁定,因为数据行并不冲突。
2、插入意向锁不会阻止任何锁,插入记录会持有记录锁。
实例
insertintotest_user(user_id,name,age)values(2,'b',10) -------TRXHASBEENWAITING18SECFORTHISLOCKTOBEGRANTED: RECORDLOCKSspaceid6628pageno4nbits72index`index_user`oftable`test`.`test_user`trxid117851203 插入意向锁 lock_modeXinsertintentionwaiting Recordlock,heapno1PHYSICALRECORD:n_fields1;compactformat;infobits0 0:len8;hex73757072656d756d;ascsupremum;;
以上就是mysql插入意向锁的使用,希望对大家有所帮助。更多mysql学习指路:MySQL