>백엔드 개발 >PHP 튜토리얼 >PHP 및 MySQL 트랜잭션으로 데이터 무결성을 어떻게 보장할 수 있습니까?

PHP 및 MySQL 트랜잭션으로 데이터 무결성을 어떻게 보장할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-23 21:33:14403검색

How Can I Ensure Data Integrity with PHP and MySQL Transactions?

MySQL 트랜잭션이 포함된 PHP의 예

PHP 및 MySQL의 트랜잭션은 일련의 데이터베이스 작업이 다음과 같이 실행되도록 하는 방법을 제공합니다. 단일 원자 단위. 이는 트랜잭션의 모든 작업이 데이터베이스에 커밋되거나 전혀 커밋되지 않음을 의미합니다.

PHP에서 트랜잭션을 사용하려면 다음 코드를 사용할 수 있습니다. snippet:

$db->beginTransaction();

$a1 = $db->query("INSERT INTO table_name VALUES (value1)");
$a2 = $db->query("INSERT INTO table_name VALUES (value2)");

if ($a1 and $a2) {
    $db->commit();
} else {
    $db->rollback();
}

이 예에서는 먼저 $db->beginTransaction()을 사용하여 트랜잭션을 시작합니다. 그런 다음 $a1 및 $a2 두 개의 쿼리를 실행하고 두 쿼리가 모두 성공하는지 확인합니다. 두 쿼리가 모두 성공하면 트랜잭션을 커밋()하여 데이터베이스에 변경 사항을 영구적으로 적용합니다. 그렇지 않으면 트랜잭션을 롤백()하고 트랜잭션 중에 발생한 모든 변경 사항을 삭제합니다.

Try-Catch를 사용한 대체 접근 방식

트랜잭션을 처리하는 또 다른 접근 방식은 try-catch 블록:

try {
    $db->beginTransaction();

    $a1 = $db->query("INSERT INTO table_name VALUES (value1)");
    $a2 = $db->query("INSERT INTO table_name VALUES (value2)");

    $db->commit();
} catch (\Throwable $e) {
    $db->rollback();
    throw $e;
}

이 접근 방식에서는 try 블록에서 트랜잭션을 시작합니다. 모든 쿼리가 성공하면 트랜잭션을 커밋합니다. 쿼리 중 하나라도 실패하면 $db->rollback()을 사용하여 트랜잭션을 롤백하고 처리를 위해 예외를 다시 발생시킵니다.

자동 트랜잭션

PHP는 모든 쿼리에 대한 트랜잭션을 자동으로 처리하는 방법을 제공하지 않습니다. BeginTransaction() 및 commit() 또는 Rollback() 메서드를 사용하여 트랜잭션에 포함되어야 하는 쿼리를 명시적으로 지정해야 합니다.

위 내용은 PHP 및 MySQL 트랜잭션으로 데이터 무결성을 어떻게 보장할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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