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 중국어 웹사이트의 기타 관련 기사를 참조하세요!