gpt4 book ai didi

php - 如何在 PHP 中为 MySQL 实现提交/回滚?

转载 作者:可可西里 更新时间:2023-11-01 06:36:21 25 4
gpt4 key购买 nike

基本上我有这个脚本,它需要很长时间才能执行,偶尔会超时,并在我的数据库中留下半完整的数据。 (是的,我知道在一个完美的世界中,我会修复它而不是实现提交和回滚,但我被迫不这样做)

这是我的基本代码(为简单起见简化了):

$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 循环的开始和结束时使用提交/回滚来执行此操作,但不知道如何做。

最佳答案

看看this tutorial关于与 PDO 的交易。

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

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

according to this PDO document page :

“当脚本结束或者连接即将关闭时,如果你有未完成的事务,PDO会自动回滚它。”

因此您将丢失脚本超时时挂起的交易。

但实际上,您应该重新设计它,使其不依赖于脚本的存活。

关于php - 如何在 PHP 中为 MySQL 实现提交/回滚?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/329622/

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