목차
고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어
트랜잭션
并发控制
백엔드 개발 PHP 튜토리얼 고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어

고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어

Jun 01, 2024 am 11:43 AM
php 데이터베이스 연결

고급 PHP 데이터베이스 연결에는 데이터 무결성을 보장하고 오류를 방지하기 위한 트랜잭션, 잠금 및 동시성 제어가 포함됩니다. 트랜잭션은 startTransaction(), commit() 및 Rollback() 메서드를 통해 관리되는 작업 집합의 원자 단위입니다. 잠금은 PDO::LOCK_SHARED 및 PDO::LOCK_EXCLUSIVE를 통한 데이터에 대한 동시 액세스를 방지합니다. 동시성 제어는 MySQL 격리 수준(커밋되지 않은 읽기, 커밋된 읽기, 반복 가능한 읽기, 직렬화 가능)을 통해 여러 트랜잭션에 대한 액세스를 조정합니다. 실제 애플리케이션에서는 데이터 무결성을 보장하고 재고 문제를 방지하기 위해 쇼핑 웹사이트의 제품 재고 관리에 트랜잭션, 잠금 및 동시성 제어가 사용됩니다.

高级 PHP 数据库连接:事务、锁和并发控制

고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어

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 提供了以下隔离级别:

  • 读未提交 (READ UNCOMMITTED):事务可以读取其他事务未提交的数据。
  • 读已提交 (READ COMMITTED):事务只能读取其他已提交的事务的数据。
  • 可重复读 (REPEATABLE READ):事务在整个生命周期内都可以看到其他已提交事务的数据,但不能看到未提交的事务的数据。
  • 串行化 (SERIALIZABLE):事务串行执行,避免任何并发冲突。

您可以在连接到数据库时通过 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);
로그인 후 복사

Lock

잠금은 트랜잭션이 동시에 동일한 데이터베이스 데이터에 액세스하는 것을 방지하는 데 사용됩니다. PHP의 PDO는 두 가지 잠금 모드를 제공합니다:

  • 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();
로그인 후 복사
동시성 제어🎜🎜동시성 제어 메커니즘은 여러 트랜잭션이 데이터베이스에 액세스할 때 발생하지 않도록 보장합니다. 동시에 데이터 충돌. MySQL은 다음과 같은 격리 수준을 제공합니다. 🎜
  • 커밋되지 않은 읽기:트랜잭션은 다른 트랜잭션에서 커밋되지 않은 데이터를 읽을 수 있습니다.
  • READ COMMITTED: 트랜잭션은 커밋된 다른 트랜잭션에서만 데이터를 읽을 수 있습니다.
  • REPEATABLE READ: 트랜잭션은 수명 주기 동안 커밋된 다른 트랜잭션의 데이터를 볼 수 있지만 커밋되지 않은 트랜잭션의 데이터는 볼 수 없습니다.
  • SERIALIZABLE: 동시성 충돌을 방지하기 위해 트랜잭션이 순차적으로 실행됩니다.
🎜데이터베이스에 연결할 때 PDO::ATTR_DEFAULT_FETCH_MODE 옵션을 통해 격리 수준을 설정할 수 있습니다. 🎜rrreee🎜실용 사례🎜🎜사용자가 다음을 수행할 수 있는 온라인 쇼핑 웹사이트를 고려해보세요. 장바구니에 제품을 추가하고 구매하세요. 여러 사용자가 동시에 동일한 제품을 장바구니에 추가하는 등의 문제를 방지하기 위해 트랜잭션, 잠금 및 동시성 제어를 사용하여 데이터 무결성을 보장할 수 있습니다. 🎜rrreee🎜 트랜잭션, 잠금 및 동시성 제어를 사용하여 , 제품 구매 시 사용자 데이터베이스 무결성을 보장하고 재고 문제를 방지할 수 있습니다. 🎜

위 내용은 고급 PHP 데이터베이스 연결: 트랜잭션, 잠금 및 동시성 제어의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Ubuntu 및 Debian용 PHP 8.4 설치 및 업그레이드 가이드 Dec 24, 2024 pm 04:42 PM

PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP 날짜 및 시간 CakePHP 날짜 및 시간 Sep 10, 2024 pm 05:27 PM

cakephp4에서 날짜와 시간을 다루기 위해 사용 가능한 FrozenTime 클래스를 활용하겠습니다.

CakePHP 데이터베이스 작업 CakePHP 데이터베이스 작업 Sep 10, 2024 pm 05:25 PM

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP 파일 업로드 CakePHP 파일 업로드 Sep 10, 2024 pm 05:27 PM

파일 업로드 작업을 위해 양식 도우미를 사용할 것입니다. 다음은 파일 업로드의 예입니다.

CakePHP 라우팅 CakePHP 라우팅 Sep 10, 2024 pm 05:25 PM

이번 장에서는 라우팅과 관련된 다음과 같은 주제를 학습하겠습니다.

CakePHP 토론 CakePHP 토론 Sep 10, 2024 pm 05:28 PM

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP 유효성 검사기 만들기 CakePHP 유효성 검사기 만들기 Sep 10, 2024 pm 05:26 PM

컨트롤러에 다음 두 줄을 추가하면 유효성 검사기를 만들 수 있습니다.

CakePHP 로깅 CakePHP 로깅 Sep 10, 2024 pm 05:26 PM

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

See all articles