首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >事务中的Mysql事务

事务中的Mysql事务
EN

Stack Overflow用户
提问于 2009-09-29 06:16:49
回答 6查看 27.9K关注 0票数 57

在使用mysql数据库的PHP脚本中,我最近需要在恰好位于另一个事务中的某个点使用另一个事务。我的所有测试似乎都表明这是正常工作的,但我找不到任何关于这种用法的文档。

我想确定-事务中的事务在mysql中是有效的吗?如果是这样的话,有没有办法找出你在嵌套事务中有多少层?(即需要多少次回滚才能恢复正常)

提前谢谢你,布赖恩

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2009-09-29 06:35:37

你可能会对手册的这一页感兴趣:;引用几句话:

本节中列出的语句(以及它们的任何同义词)隐式地结束事务,就像您在执行语句之前执行了COMMIT一样。

并且,在页面的更远的地方:

事务控制和锁定语句。BEGINLOCK TABLESSET autocommit = 1 (如果值不是1)、START TRANSACTIONUNLOCK TABLES

另请参阅本段:

事务不能嵌套。

这是在发出START TRANSACTION语句或其同义词之一时对任何当前事务执行隐式commit的结果。

票数 58
EN

Stack Overflow用户

发布于 2012-08-14 04:04:12

与其他人的答案相反,您可以在事务中有效地创建事务,这真的很容易。您只需创建保存点位置并使用ROLLBACK TO savepoint回滚事务的一部分,其中SAVEPOINT是您为保存点指定的任何名称。指向MySQL文档的链接:http://dev.mysql.com/doc/refman/5.0/en/savepoint.html,当然,事务中任何位置的查询都不应该是隐式提交的类型,否则整个事务将被提交。

示例:

代码语言:javascript
复制
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中,我写了这样的代码,它工作得很好:

代码语言:javascript
复制
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
}
票数 71
EN

Stack Overflow用户

发布于 2009-09-29 06:41:05

我想确认-事务中的事务在mysql中是有效的吗?

不是的。

票数 14
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1490846

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档