在使用mysql数据库的PHP脚本中,我最近需要在恰好位于另一个事务中的某个点使用另一个事务。我的所有测试似乎都表明这是正常工作的,但我找不到任何关于这种用法的文档。
我想确定-事务中的事务在mysql中是有效的吗?如果是这样的话,有没有办法找出你在嵌套事务中有多少层?(即需要多少次回滚才能恢复正常)
提前谢谢你,布赖恩
发布于 2009-09-29 06:35:37
你可能会对手册的这一页感兴趣:;引用几句话:
本节中列出的语句(以及它们的任何同义词)隐式地结束事务,就像您在执行语句之前执行了
COMMIT一样。
并且,在页面的更远的地方:
事务控制和锁定语句。
BEGIN、LOCK TABLES、SET autocommit = 1(如果值不是1)、START TRANSACTION、UNLOCK TABLES。
另请参阅本段:
事务不能嵌套。
这是在发出START TRANSACTION语句或其同义词之一时对任何当前事务执行隐式commit的结果。
发布于 2012-08-14 04:04:12
与其他人的答案相反,您可以在事务中有效地创建事务,这真的很容易。您只需创建保存点位置并使用ROLLBACK TO savepoint回滚事务的一部分,其中SAVEPOINT是您为保存点指定的任何名称。指向MySQL文档的链接:http://dev.mysql.com/doc/refman/5.0/en/savepoint.html,当然,事务中任何位置的查询都不应该是隐式提交的类型,否则整个事务将被提交。
示例:
START TRANSACTION;
# queries that don't implicitly commit
SAVEPOINT savepoint1;
# queries that don't implicitly commit
# now you can either ROLLBACK TO savepoint1, or just ROLLBACK to reverse the entire transaction.
SAVEPOINT savepoint2;
# queries that don't implicitly commit
# now you can ROLLBACK TO savepoint1 OR savepoint2, or ROLLBACK all the way.
# e.g.
ROLLBACK TO savepoint1;
COMMIT; # results in committing only the part of the transaction up to savepoint1在PHP中,我写了这样的代码,它工作得很好:
foreach($some_data as $key => $sub_array) {
$result = mysql_query('START TRANSACTION'); // note mysql_query is deprecated in favor of PDO
$rollback_all = false; // set to true to undo whole transaction
for($i=0;$i<sizeof($sub_array);$i++) {
if($sub_array['set_save'] === true) {
$savepoint = 'savepoint' . $i;
$result = mysql_query("SAVEPOINT $savepoint");
}
$sql = 'UPDATE `my_table` SET `x` = `y` WHERE `z` < `n`'; // some query/queries
$result = mysql_query($sql); // run the update query/queries
$more_sql = 'SELECT `x` FROM `my_table`'; // get data for checking
$result = mysql_query($more_sql);
$rollback_to_save = false; // set to true to undo to last savepoint
while($row = mysql_fetch_array($result)) {
// run some checks on the data
// if some check says to go back to savepoint:
$rollback_to_save = true; // or just do the rollback here.
// if some check says to rollback entire transaction:
$rollback_all = true;
}
if($rollback_all === true) {
mysql_query('ROLLBACK'); // rollback entire transaction
break; // break out of for loop, into next foreach
}
if($rollback_to_save = true) {
mysql_query("ROLLBACK TO $savepoint"); // undo just this part of for loop
}
} // end of for loop
mysql_query('COMMIT'); // if you don't do this, the whole transaction will rollback
}发布于 2009-09-29 06:41:05
我想确认-事务中的事务在mysql中是有效的吗?
不是的。
https://stackoverflow.com/questions/1490846
复制相似问题