고급 PHP 데이터베이스 연결에는 데이터 무결성을 보장하고 오류를 방지하기 위한 트랜잭션, 잠금 및 동시성 제어가 포함됩니다. 트랜잭션은 startTransaction(), commit() 및 Rollback() 메서드를 통해 관리되는 작업 집합의 원자 단위입니다. 잠금은 PDO::LOCK_SHARED 및 PDO::LOCK_EXCLUSIVE를 통한 데이터에 대한 동시 액세스를 방지합니다. 동시성 제어는 MySQL 격리 수준(커밋되지 않은 읽기, 커밋된 읽기, 반복 가능한 읽기, 직렬화 가능)을 통해 여러 트랜잭션에 대한 액세스를 조정합니다. 실제 애플리케이션에서는 데이터 무결성을 보장하고 재고 문제를 방지하기 위해 쇼핑 웹사이트의 제품 재고 관리에 트랜잭션, 잠금 및 동시성 제어가 사용됩니다.
PHP를 사용하여 데이터베이스와 상호 작용할 때 트랜잭션, 잠금 및 동시성 제어와 같은 고급 개념을 이해하는 것은 데이터 무결성을 보장하고 애플리케이션의 오류를 방지하는 데 중요합니다.
트랜잭션은 원자 단위로 실행되는 데이터베이스 작업의 모음입니다. 이는 트랜잭션의 모든 작업이 모두 성공하거나 모두 실패함을 의미합니다.
beginTransaction()
, commit()
및 rollback()
메서드를 사용하여 트랜잭션을 시작, 커밋 및 롤백합니다. beginTransaction()
、commit()
和 rollback()
方法来启动、提交和回滚事务:
$db->beginTransaction(); try { // 执行数据库操作 $db->commit(); } catch (\Exception $e) { $db->rollback(); }
锁用于防止事务同时访问相同的数据库数据。PHP 的 PDO 提供了两种锁定模式:
PDO::LOCK_SHARED
:允许事务读取数据,但不能写入。PDO::LOCK_EXCLUSIVE
:允许事务读取和写入数据,但其他事务无法同时访问。要通过 query()
方法对表行进行锁定:
$stmt = $db->query('SELECT * FROM table WHERE id = 1 FOR UPDATE');
并发控制机制确保当多个事务同时访问数据库时不会发生数据冲突。MySQL 提供了以下隔离级别:
您可以在连接到数据库时通过 PDO::ATTR_DEFAULT_FETCH_MODE
$db->setAttribute(PDO::ATTR_DEFAULT_FETCH_MODE, PDO::FETCH_ASSOC); $db->setAttribute(PDO::ATTR_TRANSACTION_ISOLATION, PDO::ISOLATION_READ_COMMITTED);
PDO::LOCK_SHARED
: 트랜잭션이 데이터를 읽을 수는 있지만 쓸 수는 없습니다. PDO::LOCK_EXCLUSIVE
: 트랜잭션은 데이터를 읽고 쓸 수 있지만 다른 트랜잭션은 동시에 데이터에 액세스할 수 없습니다. query()
메소드를 통해 테이블 행을 잠그려면: // 启动事务 $db->beginTransaction(); // 锁定产品行 $stmt = $db->query('SELECT * FROM products WHERE id = :id FOR UPDATE'); $stmt->bindParam(':id', $productId); $stmt->execute(); // 获取产品数量 $product = $stmt->fetch(); $quantity = $product['quantity']; // 检查库存 if ($quantity <= 0) { $db->rollback(); throw new RuntimeException('Product is out of stock.'); } // 更新库存 $quantity--; $stmt = $db->prepare('UPDATE products SET quantity = :quantity WHERE id = :id'); $stmt->bindParam(':quantity', $quantity); $stmt->bindParam(':id', $productId); $stmt->execute(); // 提交事务 $db->commit();
PDO::ATTR_DEFAULT_FETCH_MODE
옵션을 통해 격리 수준을 설정할 수 있습니다. 🎜rrreee🎜실용 사례🎜🎜사용자가 다음을 수행할 수 있는 온라인 쇼핑 웹사이트를 고려해보세요. 장바구니에 제품을 추가하고 구매하세요. 여러 사용자가 동시에 동일한 제품을 장바구니에 추가하는 등의 문제를 방지하기 위해 트랜잭션, 잠금 및 동시성 제어를 사용하여 데이터 무결성을 보장할 수 있습니다. 🎜rrreee🎜 트랜잭션, 잠금 및 동시성 제어를 사용하여 , 제품 구매 시 사용자 데이터베이스 무결성을 보장하고 재고 문제를 방지할 수 있습니다. 🎜위 내용은 고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!