欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 家装 > MySQL 锁

MySQL 锁

2025/3/20 11:28:52 来源:https://blog.csdn.net/a1241436267/article/details/146322797  浏览:    关键词:MySQL 锁

MySQL中最常见的锁有全局锁、表锁、行锁。


全局锁

全局锁用于锁住当前库中的所有实例,也就是说会将所有的表都锁住。一般用于做数据库备份的时候就需要添加全局锁,数据库备份的时候是一个表一个表备份,如果没有加锁的话在备份的时候会有其他的事务进行提交,从而造成数据不一致,加锁后能保证在备份的时候不会有其他事务提交数据。


如何添加一个全局锁呢?

通过以下命令添加一个全局锁

#设置全局锁
flush tables with read lock;

执行增删改操作,会发现当前锁冲突,无法操作

insert into user (username, password, phone) 
values ('Jack', '$2a$10$6ptTq3V9XfaJmFYwYT2W9ud377BUkEWk.whf.iQ.0sX5F.L497rAC', '12345678901');


执行读取操作

#读取userselect *from user;


可以发现,添加全局锁后,整个数据库都变成了只读状态,操作完别忘记释放全局锁。

#释放全局锁
unlock tables;

表级锁

表级锁可细分为表锁、元数据锁、意向锁

  • 表锁:表锁有读锁和写锁,读锁当前客户端可读不可写(报错),其他客户端可读不可写(阻塞,直到释放锁)。写锁只有当前客户端可读可写,其他客户端不可读不可写        
  • 元数据锁:元数据锁分为读锁和写锁,读锁之间是共享的,即多个事务之间能同时读取数据,而写锁是排他的,主要为了防止在写的过程中数据结构发生改变,写锁同一时间只能被一个事务获取
  • 意向锁:意向锁的主要目的是减少行锁和表锁之间的冲突。意向锁能够快速判断是否发生锁冲突从而无需逐行检查每一行数据。意向锁可细分为共享锁和排他锁,共享锁之间是兼容的多个事务可以同时拥有,而排他锁是互斥的只能有一个事务持有
    SELECTobject_schema,object_name,index_name,lock_type,lock_mode,lock_data
    FROMperformance_schema.data_locks;

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词