PHP + MySQL 事务示例

2022-08-30 06:03:56

我真的没有找到使用MySQL事务的PHP文件的正常示例。你能给我看一个简单的例子吗?

还有一个问题。我已经做了很多编程,但没有使用事务。我可以放一个PHP函数或其他东西,如果一个失败,那么其他的也会失败吗?header.phpmysql_query


我想我已经想通了,对吗?

mysql_query("SET AUTOCOMMIT=0");
mysql_query("START TRANSACTION");

$a1 = mysql_query("INSERT INTO rarara (l_id) VALUES('1')");
$a2 = mysql_query("INSERT INTO rarara (l_id) VALUES('2')");

if ($a1 and $a2) {
    mysql_query("COMMIT");
} else {        
    mysql_query("ROLLBACK");
}

答案 1

我在处理事务时通常使用的想法如下所示(半伪代码):

try {
    // First of all, let's begin a transaction
    $db->beginTransaction();
    
    // A set of queries; if one fails, an exception should be thrown
    $db->query('first query');
    $db->query('second query');
    $db->query('third query');
    
    // If we arrive here, it means that no exception was thrown
    // i.e. no query has failed, and we can commit the transaction
    $db->commit();
} catch (\Throwable $e) {
    // An exception has been thrown
    // We must rollback the transaction
    $db->rollback();
    throw $e; // but the error must be handled anyway
}

请注意,有了这个想法,如果查询失败,则必须引发异常:
  • PDO可以做到这一点,这取决于你如何配置它。
  • 否则,使用其他一些 API,您可能必须测试用于执行查询的函数的结果,并自行引发异常。

不幸的是,没有魔法。你不能只是把一条指令放在某个地方,然后自动完成事务:你仍然必须指定在事务中必须执行哪组查询。

例如,通常情况下,在事务之前在开始之前有几个查询,在事务之后在提交回滚之后)还有几个查询,无论事务中发生(或未发生)什么,您都希望执行这些查询。


答案 2

我想我已经想通了,对吗?

mysql_query("START TRANSACTION");

$a1 = mysql_query("INSERT INTO rarara (l_id) VALUES('1')");
$a2 = mysql_query("INSERT INTO rarara (l_id) VALUES('2')");

if ($a1 and $a2) {
    mysql_query("COMMIT");
} else {        
    mysql_query("ROLLBACK");
}

推荐