gpt4 book ai didi

PHP + MySQL 事务示例

转载 作者:行者123 更新时间:2023-11-30 22:11:16 24 4
gpt4 key购买 nike

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

还有一个问题。我已经做了很多编程并且没有使用事务。我可以在 header.php 中放置一个 PHP 函数或其他东西,如果一个 mysql_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");
}

最佳答案

我在处理事务时通常使用的想法看起来像这样(半伪代码):

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,您可能必须测试用于执行查询的函数的结果,然后自己抛出异常。

不幸的是,没有魔法参与。您不能只在某处放置一条指令并让交易自动完成:您仍然必须指定必须在交易中执行哪组查询。

例如,您经常会在交易前(在开始之前)和交易后的另外几个查询(在 commitrollback) 之后,无论事务中发生什么(或不发生),您都希望执行这些查询.

关于PHP + MySQL 事务示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40061209/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com