gpt4 book ai didi

php - SQL查询失败但事务回滚不起作用

转载 作者:行者123 更新时间:2023-11-29 14:04:16 25 4
gpt4 key购买 nike

实际的列名称是 account 和 passwd,因此第二个查询将失败,但第一个查询仍然插入到数据库中。

$sql1 = "INSERT INTO users (account, passwd) VALUES ('account+1', 'password+1')";
$sql2 = "INSERT INTO users (account, password) VALUES ('account+2', 'password+2')";
try {

$db->beginTransaction();
$db->query($sql1);
$db->query($sql2);
$db->commit();

} catch (Exception $e) {
$db->rollback();
die($e->getMessage());
}

事务成功启动,没有错误,问题是它不会回滚,无论查询失败,总是插入行。

MySQL版本5.5.25,表类型为InnoDB。

最佳答案

您是否开启了异常(exception)?默认情况下,pdo 不会抛出它们并默默地忽略错误。

$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

关于php - SQL查询失败但事务回滚不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14609478/

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