php mysql 事务回滚,php mysqli事务回滚无效

如题:

// 开始事务

$mysqli->autocommit(false); // 设置为不自动提交,因为MYSQL默认立即执行

$stmt = $mysqli->prepare("update seat_table set count = count + 1 where seat_id = ? and count < 50");

$stmt->bind_param("i", $old_seat_id);

if ($stmt->execute()) {

$stmt->close();

$stmt = $mysqli->prepare("update seat_table set count = count-1 where bus_id = ? and seattime = ? and count > 0");

$stmt->bind_param("is", $bus_id, $seattime);

if ($stmt->execute()) {

$mysqli->commit(); // 提交

/* 判定事务终止,重新启用负载均衡 */

$mysqli->autocommit(TRUE);

$mysqli->close();

// if ($flag == 1) { // 执行退款业务

// }

echo json_encode(array(

"code" => "200",

"order_id" => $stmt->insert_id

));

} else { // 减库失败

$mysqli->rollback();

die('1500');

}

} else { // 回库失败

$mysqli->rollback();

die('2500');

}

首先我这个语句报了错,报Fatal error: Call to a member function bind_param() on a non-object ,报错地方在第一个语句(加库存操作count=count+1),但是无解为什么报错,语句是不会错的,在命令行可正确执行

然而就算报错了,却仍然被执行了(十万个程序员问号),结果就是库存加了1,要减的没有变化。

我蒙蔽了,大半夜的很头痛。

求助问题所在!!非常感谢!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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、付费专栏及课程。

余额充值