当前位置:首页 > PHP

php 实现乐观锁实现

2026-01-30 05:07:40PHP

乐观锁的概念

乐观锁是一种并发控制机制,假设多用户并发操作时不会产生冲突,因此不加锁。只在数据提交时检查数据是否被其他事务修改过。通常通过版本号(Version)或时间戳(Timestamp)实现。

实现乐观锁的核心步骤

数据库表设计
在表中添加一个版本号字段(如version),每次更新数据时版本号递增。

CREATE TABLE products (
    id INT PRIMARY KEY,
    name VARCHAR(100),
    stock INT,
    version INT DEFAULT 0
);

更新数据的逻辑

  1. 读取数据时获取当前版本号。
  2. 更新时检查版本号是否与读取时一致,若一致则更新并递增版本号。
// 假设从数据库获取的数据
$productId = 1;
$currentVersion = 5; // 读取时的版本号
$newStock = 10;

// 更新语句,通过版本号校验
$sql = "UPDATE products SET stock = :stock, version = version + 1 
        WHERE id = :id AND version = :version";
$stmt = $pdo->prepare($sql);
$stmt->bindParam(':stock', $newStock);
$stmt->bindParam(':id', $productId);
$stmt->bindParam(':version', $currentVersion);
$affectedRows = $stmt->execute();

if ($affectedRows === 0) {
    // 更新失败,版本号已变更或数据不存在
    throw new Exception("并发冲突,数据已被修改");
}

使用时间戳实现乐观锁

若不想用版本号,可用last_updated字段记录时间戳。

php 实现乐观锁实现

ALTER TABLE products ADD COLUMN last_updated TIMESTAMP;
$lastUpdated = '2023-10-01 12:00:00'; // 读取时的时间戳
$sql = "UPDATE products SET stock = :stock, last_updated = NOW() 
        WHERE id = :id AND last_updated = :lastUpdated";
// 其他逻辑与版本号类似

乐观锁的适用场景

  • 读多写少的场景,冲突概率低。
  • 需要高并发性能,避免悲观锁的开销。

注意事项

  • 冲突时需重试或提示用户重新操作。
  • 长时间操作可能因版本号失效导致重试次数增多。

通过版本号或时间戳的比对,可以简单高效地实现乐观锁机制。

标签: 乐观php
分享给朋友:

相关文章

php实现websocket

php实现websocket

PHP 实现 WebSocket WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。PHP 可以通过多种方式实现 WebSocket 功能,以下是几种常见的方法: 使用 Ratc…

php验证码实现

php验证码实现

验证码实现方法 在PHP中实现验证码功能通常涉及生成随机字符串或数字,将其转换为图像,并通过会话(Session)进行验证。以下是几种常见的实现方式: 使用GD库生成图像验证码 GD库是PHP内置的…

php验证码的实现

php验证码的实现

PHP 验证码实现方法 使用 GD 库生成基础验证码 创建画布并生成随机字符串作为验证码内容: session_start(); $width = 120; $height = 40; $image…

php实现分类

php实现分类

PHP实现分类的方法 数据库设计 创建分类表时,通常需要包含id、名称、父级id等字段。父级id用于实现多级分类结构。 CREATE TABLE categories ( id INT AU…

php 队列的实现

php 队列的实现

PHP 队列的实现方法 使用数据库实现队列 创建一个数据表存储队列任务,包含任务ID、状态、创建时间等字段。通过SQL语句实现任务的入队和出队操作。 // 入队操作 INSERT INTO queu…

php数组实现

php数组实现

PHP 数组的基本实现 PHP 数组是一种非常灵活的数据结构,可以存储多个值,并且支持多种类型的键(整数或字符串)。PHP 数组实际上是有序映射(ordered map),可以看作是列表(vector…