mysql 中的共享锁与排他锁的运用

在MySQL的InnoDB存储引擎中,锁是管理并发访问数据的关键机制。主要有两种类型的锁:共享锁和排他锁。

1、共享锁(Shared Lock)
作用:允许多个事务同时读取同一数据,但不允许修改。
使用场景:适用于读多写少的场景,保证数据一致性读。
注意:可能导致死锁,尤其是在高并发环境下。
命令:执行如下SQL语句时,会为查询结果集中的每一行数据加上共享锁。

SELECT … LOCK IN SHARE MODE;

2、排他锁(Exclusive Lock)
作用:阻止其他事务读取或修改数据,直到锁被释放。
使用场景:需要读取并更新同一数据时,确保数据一致性和完整性。
注意:
仅适用于InnoDB,且必须在事务中。
使用索引锁定行,避免表锁。
会阻塞其他事务的读写操作。
命令:执行如下SQL语句时,会为查询结果集中的每一行数据加上排他锁。

— 使用排他锁读取用户余额(假设用户表名为users)
SELECT balance FROM users WHERE user_id = 456 FOR UPDATE;

 

欢迎使用66资源网
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
7. 本站有不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别!

66源码网 » mysql 中的共享锁与排他锁的运用

提供最优质的资源集合

立即查看 了解详情