当前位置:  开发笔记 > 编程语言 > 正文

如何在PHP中实现MySQL的提交/回滚?

如何解决《如何在PHP中实现MySQL的提交/回滚?》经验,为你挑选了1个好方法。

基本上我有这个脚本需要很长时间才能执行,偶尔会超时并且会在我的数据库周围留下半完整的数据.(是的,我知道在一个完美的世界中我会解决这个问题,而不是实现提交和回滚,但我不得不这样做)

这是我的基本代码(为简单而愚蠢):

$database = new PDO("mysql:host=host;dbname=mysql_db","username","password");

while (notDone())
{
    $add_row = $database->prepare("INSERT INTO table (columns) VALUES (?)");
    $add_row->execute(array('values'));

    //PROCESSING STUFF THAT TAKES A LONG TIME GOES HERE
}

$database = null;

所以我的问题是,如果那个while循环中的整个过程没有完成,那么我不希望插入的行保留在那里.我认为我可以在while循环的开头和结尾处使用提交/回滚来执行此操作,但不知道如何操作.



1> Brian C. Lan..:

看一下关于PDO交易的本教程.

基本上将长时间运行的代码包装在:

$dbh->beginTransaction();
...
$dbh->commit();

并根据此PDO文档页面:

"当脚本结束或连接即将关闭时,如果您有未完成的事务,PDO将自动回滚."

因此,当脚本超时时,您将丢失待处理的事务.

但实际上,你应该重新设计它,以便它不依赖于留着活着的抄写员.

推荐阅读
mobiledu2402851323
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有