php修改数据失败回滚,PHP异步请求API,失败后直接回滚

说白了就是一个程序设计的问题,基于事务的话可以:

function save_if_success($transaction, $result)

{

if ($result) $transaction->commit();

else $transaction->rollback();

}

$db_ret = db();

save_if_success($transaction, api1($db_ret) && api2($db_ret));

缺点是只能数据库回滚

一般最好是自己实现撤销逻辑,既可以撤销数据库操作,又可以撤销api操作,用异常会很方便

function revoke_if_failed($do_func, $do_func_params, $revoke_callback, $revoke_params, $exception) {

try

{

$do_func_ret = call_user_func_array($do_func, $do_func_params);

}

catch($exception $e)

{

call_user_func_array($revoke_callback, $revoke_params);

throw;

}

return $do_func_ret;

}

try

{

$dbret = db();

$api1_ret = revoke_if_failed(api1, [$dbret], revoke_db, [$dbret], OperationFailedException::class);

revoke_if_failed(api2, [$api1_ret], revoke_api1, [$api1_ret], OperationFailedException::class);

}

catch (OperationFailedException $e)

{

return ERR;

}

return SUCCESS;

也可以结合起来用

PHP中,可以使用mysqli或PDO扩展来操作MySQL数据库。无论使用哪种扩展,回滚操作都是类似的。 回滚操作通常用于撤销之前的事务,以确保数据的完整性。例如,当插入或更新多个表时,如果其中一个操作失败,您可能需要回滚整个事务,以确保所有表都保持一致状态。 下面是一个简单的示例,演示如何在PHP中执行回滚操作: 使用mysqli扩展: ``` // 连接到数据库 $conn = mysqli_connect("localhost", "username", "password", "dbname"); // 开始事务 mysqli_begin_transaction($conn); try { // 执行一些数据库操作 // 如果操作失败,则回滚事务 if (some_condition) { mysqli_rollback($conn); } // 提交事务 mysqli_commit($conn); } catch (Exception $e) { // 发生异常时回滚事务 mysqli_rollback($conn); } // 关闭数据库连接 mysqli_close($conn); ``` 使用PDO扩展: ``` // 连接到数据库 $conn = new PDO("mysql:host=localhost;dbname=db", "username", "password"); // 开始事务 $conn->beginTransaction(); try { // 执行一些数据库操作 // 如果操作失败,则回滚事务 if (some_condition) { $conn->rollBack(); } // 提交事务 $conn->commit(); } catch (Exception $e) { // 发生异常时回滚事务 $conn->rollBack(); } // 关闭数据库连接 $conn = null; ``` 无论使用mysqli还是PDO扩展,回滚操作都需要在事务中执行。在示例中,我们使用了try-catch块来捕获异常并回滚事务。如果没有发生异常,则提交事务。如果有任何操作失败,则回滚事务。最后,我们关闭数据库连接。 请注意,回滚操作只能在事务中执行。如果您没有使用事务,则无法执行回滚操作。因此,在执行任何数据库操作之前,请确保已启用事务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值