首页 > 数据库 >MYSQL排它锁获取机制

MYSQL排它锁获取机制

时间:2024-08-19 15:07:49浏览次数:19  
标签:product 事务 排它 显式 UPDATE 获取 MYSQL id

在数据库系统中,排他锁(Exclusive Lock)用于确保在一个事务对数据进行修改时,其他事务无法访问或修改相同的数据。这种机制确保了数据的完整性和一致性。

获取排他锁的方式包括自动获取和手动获取,下面我将详细整理这两种方式的机制。

自动获取排他锁

  1. 行级别的排他锁(自动)

    • 场景:当你执行修改操作(如 UPDATE, DELETE)时,数据库系统会自动在操作的行上获取排他锁。
    • 机制
      • 操作执行:例如,当执行 UPDATE 语句时,数据库首先定位符合条件的行。
      • 加锁:自动在这些行上加上排他锁,以防止其他事务在同一时间对这些行进行修改。
      • 事务管理:锁会持续到事务提交(COMMIT)或回滚(ROLLBACK)为止。
    • 示例:  
      START TRANSACTION;
      
      UPDATE products SET price = price * 1.10 WHERE product_id = 1;
      -- 对 product_id = 1 的行加上行级排他锁
      
      COMMIT;
    •  

手动获取排他锁

  1. 手动行级排他锁

    • 场景:在某些情况下,你可能需要显式地对某些行加排他锁。
    • 机制
      • 操作执行:使用特定的 SQL 语句来显式地请求排他锁(如 SELECT ... FOR UPDATE)。
      • 加锁:显式地在查询结果集的行上加排他锁,防止其他事务对这些行进行修改。
      • 事务管理:锁会持续到事务提交或回滚为止。
    • 示例
      START TRANSACTION;
      
      SELECT * FROM products WHERE product_id = 1 FOR UPDATE;
      -- 对 product_id = 1 的行加上行级排他锁
      
      UPDATE products SET price = price * 1.10 WHERE product_id = 1;
      
      COMMIT;
  2. 手动表级排他锁

    • 场景:在特定情况下,你可能需要显式地对整个表加排他锁。
    • 机制
      • 操作执行:使用 LOCK TABLES ... WRITE 语句来显式地锁定整个表。
      • 加锁:显式地对整个表加上排他锁,防止其他事务对表中的数据进行读取或修改。
      • 事务管理:锁会持续到 UNLOCK TABLES 语句执行,或者事务提交或回滚为止。
    • 示例
      LOCK TABLES products WRITE;
      
      -- 对整个表加上排他锁
      
      INSERT INTO products (product_id, product_name, price) VALUES (4, 'Monitor', 200.00);
      
      UNLOCK TABLES;

总结

  • 自动获取排他锁:通常在执行修改操作(如 UPDATE, DELETE)或使用表级别锁时,由数据库系统自动处理。这种方式确保了在事务执行期间数据的一致性和完整性。

  • 手动获取排他锁:通过显式的 SQL 语句(如 SELECT ... FOR UPDATE, LOCK TABLES ... WRITE)进行。这种方式提供了更多的控制权,适用于特定的锁定需求。

了解这些锁的机制可以帮助你更有效地管理数据库事务,避免并发操作中的冲突,提高数据操作的效率和可靠性。

标签:product,事务,排它,显式,UPDATE,获取,MYSQL,id
From: https://www.cnblogs.com/zhanchenjin/p/18367310

相关文章

  • Mysql - 主键索引和唯一索引的异同点
    唯一索引:唯一性:唯一索引保证索引列的值是唯一的,不会有重复。比如,一个班级的学号,每个学生都有一个唯一的学号,不能有重复。可以有多个:一个数据库表中可以有多个唯一索引,就像一个班级可以有多个科目,每个科目都可以有一个唯一的成绩单。允许空值:唯一索引列中可以有一些空值(没有填写的......
  • MySQL 共享锁之表级锁:使用与实例详解
    在数据库管理中,锁机制是确保数据一致性与完整性的关键工具之一。MySQL中的共享锁(SharedLock)是一种允许多个事务并发读取数据但禁止修改的锁类型。共享锁不仅可以作用于单行数据,还可以作用于整个表。当共享锁用于表级别时,它能有效防止数据在读取期间被修改,从而确保数据的一致性。......
  • MySQL共享锁:使用与实例详解
    在关系型数据库的使用中,锁机制是保障数据一致性和完整性的关键工具。尤其在并发环境下,合理使用锁可以有效避免数据冲突与不一致问题。本文将详细介绍MySQL中的共享锁(SharedLock),并通过实际案例展示其具体应用场景。1.什么是共享锁(SharedLock)?共享锁,也称为读锁(ReadLock),是MySQL......
  • 简单的php连接mysql类
    <?phpclassDB{private$hostname;//数据库主机private$dbname;//数据库private$username;//数据库用户名private$password;//数据库密码private$port;//数据库端口public$db;//连接后的数据库对象//构造函数publicfunction__......
  • MySQL 安装与配置教程:单机、主从复制与集群模式
    目录MySQL简介MySQL安装MySQL基础配置MySQL主从复制配置MySQL集群配置总结1.MySQL简介MySQL是一个广泛使用的关系型数据库管理系统,具有高性能、高可靠性和易用性等特点。它支持多种部署模式,包括单机模式、主从复制模式(用于高可用性和读写分离)以及集群模式(用于分......
  • mysql相关命令学习
    查看mysql服务是否启动service mysql status Windows下通过任务管理器即可查看启动mysql服务service mysql start登录Mysqlmima #查看用户密码可以看到两个用户一个是root一个是admin,然后还有登录密码。启动:mysql -u用户名 -p密码mysql -u用户名......
  • 使用duckdb加载mysql
    安装duckdbhttps://duckdb.org/docs/installation/index加载mysql扩展https://duckdb.org/docs/extensions/mysql.html离线安装的话,可以等INSTALLmysql;超时后,根据它提示的URL到有网环境下载,再传到服务器挂载Nginx,修改/etc/hosts指向,再重新执行INSTALL。Demo代码如下:import......