Mysql数据库InnoDB引擎的锁

本文详细介绍了MySQL默认引擎InnoDB的锁机制,包括行锁和表锁的概念、具体应用场景及其实现方式。同时,还解释了意向锁的作用及SQL语句如何使用不同的锁。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 概述

      Mysql常用引擎有MYISAM和InnoDB,而InnoDB是mysql默认的引擎。MYISAM不支持行锁,而InnoDB支持行锁和表锁。

  • 行锁:
  1. 共享锁(S):允许一个事务去读一行,阻止其他事务获得相同的数据集的排他锁(读的时候,其他可以读,但是不能写)。
  2. 排他锁(X):允许获得排他锁的事务更新数据,但是阻止其他事务获得相同数据集的共享锁和排他锁(写的时候,其他事物不能读和写)。
  • sql语句中锁使用

    对于UPDATE、DELETE和INSERT语句,InnoDB会自动给涉及数据集加排他锁;

    对于普通SELECT语句,InnoDB不会加任意锁,当前读(特殊的读操作,需手动加上共享锁)。

  1. SELECT * FROM table_name WHERE ... LOCK IN SHARE MODE;  #共享锁
  2. SELECT * FROM table_name WHERE ... FOR UPDATE;  #排他锁
  3. insert into table values (…);    #排他锁
  4. update table set ? where ?;    #排他锁
  5. delete from table where ?;    #排他锁
  • 表级锁相关
  1. 为了允许行锁和表锁共存,实现多粒度锁机制,InnoDB还有两种内部使用的意向锁(意向共享锁(IS)和意向排他锁(IX))。这两种意向锁都是表锁。意向锁是InnoDB自动加的,不需要用户干预。
  2. mysql的行锁是通过索引加载的,即行锁是加在索引响应的行上的,要是对应的SQL语句没有走索引,则会全表扫描,行锁则无法实现,取而代之的是表锁。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值