• ADADADADAD

    Mysql-InnoDB锁的示例分析[ mysql数据库 ]

    mysql数据库 时间:2024-11-29 09:51:59

    作者:文/会员上传

    简介:

    锁类型行级锁锁模式只有LOCK_S 和LOCK_X,其他的 FLAG 用于锁的描述,如前述 LOCK_GAP、LOCK_REC_NOT_GAP 以及 LOCK_ORDINARY、LOCK_INSERT_INTENTION 四种描述。(相关推荐:MySQL

    以下为本文的正文内容,内容仅供参考!本站为公益性网站,复制本文以及下载DOC文档全部免费。

    锁类型

    行级锁

    锁模式只有LOCK_S 和LOCK_X,其他的 FLAG 用于锁的描述,如前述 LOCK_GAP、LOCK_REC_NOT_GAP 以及 LOCK_ORDINARY、LOCK_INSERT_INTENTION 四种描述。(相关推荐:MySQL教程)

    LOCK_REC_NOT_GAP

    LOCK_GAP

    LOCK_ORDINARY(Next-Key Lock)

    LOCK_INSERT_INTENTION

    static const byte lock_compatibility_matrix[5][5] = {/** IS IX S X AI // IS / { TRUE, TRUE, TRUE, FALSE, TRUE},/ IX / { TRUE, TRUE, FALSE, FALSE, TRUE},/ S / { TRUE, FALSE, TRUE, FALSE, FALSE},/ X / { FALSE, FALSE, FALSE, FALSE, FALSE},/ AI / { TRUE, TRUE, FALSE, FALSE, FALSE}};

    对于GAP类型(锁对象建立在supremum上或者申请的锁类型为LOCK_GAP)且申请的不是插入意向锁时,无需等待任何锁,这是因为不同Session对于相同GAP可能申请不同类型的锁,而GAP锁本身设计为不互相冲突;
    LOCK_ORDINARY 或者LOCK_REC_NOT_GAP类型的锁对象,无需等待LOCK_GAP类型的锁;
    LOCK_GAP类型的锁无需等待LOCK_REC_NOT_GAP类型的锁对象;
    任何锁请求都无需等待插入意向锁。

    表级锁

    InnoDB的表级别锁包含五种锁模式:LOCK_IS、LOCK_IX、LOCK_X、LOCK_S以及LOCK_AUTO_INC锁,锁之间的相容性遵循数组lock_compatibility_matrix中的定义。

    InnoDB表级锁的目的是为了防止DDL和DML的并发问题。但从5.5版本开始引入MDL锁后,InnoDB层的表级锁的意义就没那么大了,MDL锁本身已经覆盖了其大部分功能。

    意向锁是表级别的,IS和IX锁之间相互并不冲突,但与表级S/X锁冲突。
    在对记录加S锁或者X锁时,必须保证其在相同的表上有对应的意向锁或者锁强度更高的表级锁。

    Mysql-InnoDB锁的示例分析.docx

    将本文的Word文档下载到电脑

    推荐度:

    下载