我真的还没有找到使用MySQL事务的PHP文件的正常示例。你能给我简单的例子吗?
还有一个问题。我已经做了很多编程工作,并且没有使用事务。我可以放置一个PHP函数或其他东西吗header.php,如果其中一个mysql_query失败了,那么其他人也失败了?
header.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 (Exception $e) { // An exception has been thrown // We must rollback the transaction $db->rollback(); }
请注意,根据这种想法,如果查询失败,则必须引发Exception:
PDO::setAttribute
PDO::ATTR_ERRMODE
PDO::ERRMODE_EXCEPTION
不幸的是,没有涉及魔术。您不能只是在某处放置指令并自动完成事务:您仍然必须指定必须在事务中执行哪一组查询。
例如,通常您会在交易 之前(在之前begin)有_几个查询,在交易 _之后(在commit或rollback_之后 ) 又有几个查询 ,无论_ 您发生什么 (或没有 发生 ) ,您都希望执行这些查询。交易。
begin
commit
rollback