【发布时间】:2020-11-01 03:12:52
【问题描述】:
数据库类型: MariaDB
表引擎: InnoDB
我有一个表,里面有一个值正在递增的列(不是自动的,在这个表中没有插入)
当我在 phpMyAdmin 中运行以下 SQL 查询时,它可以正常工作:
UPDATE `my_table`
SET `my_column` = LAST_INSERT_ID(`my_column` + 1)
WHERE `my_column2` = 'abc';
SELECT LAST_INSERT_ID();
当查询发生时,上面返回了my_column 表的最后一个值。此查询直接取自有关锁定的 mysql 文档:https://dev.mysql.com/doc/refman/8.0/en/innodb-locking-reads.html(到底部),当您不希望计数器受到其他连接的影响时,这似乎是使用计数器的推荐方式。
我的 PDO:
try {
$conn = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
// set the PDO error mode to exception
$conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$sql = "UPDATE `my_table`
SET `my_column` = LAST_INSERT_ID(`my_column` + 1)
WHERE `my_column2` = 'abc';
SELECT LAST_INSERT_ID();";
// Prepare statement
$stmt = $conn->prepare($sql);
// execute the query
$stmt->execute();
$result = $stmt->fetchColumn(); // causes general error
$result = $stmt->fetch(PDO::FETCH_ASSOC);// causes general error
// echo a message to say the UPDATE succeeded
echo $stmt->rowCount() . " records UPDATED successfully";
} catch(PDOException $e) {
echo $sql . "<br>" . $e->getMessage();
}
$conn = null;
确切的错误SQLSTATE[HY000]: General error,如果我删除我尝试获取结果的行,它会更新列,但我仍然没有返回结果......我如何执行更新查询并获得选择像我在 phpMyAdmin 中运行它时那样一次性完成?这一切都需要按照 MySQL 文档的规定一次性完成,因此我不会遇到两个连接可能获得相同计数器的问题。
【问题讨论】:
-
不要无缘无故地捕获异常。捕获和显示错误消息完全没有意义。
-
@Dharman 谢谢,但我将如何获得我想要的价值?我还从教程中获取了 PDO 的 sn-p,我以前从未真正使用过 PDO,但我想转向它。为什么我不应该捕获异常,以便以后可以执行诸如创建日志之类的任务,以便以后查看?我刚刚发布了 sn-p 如果真的发生异常我会做更多的工作
-
错误日志记录应该是您应用程序的通用任务。如果你不知道如何实现一个复杂的错误记录器,那就让 PHP 来做吧。 PHP 内置了一个更简单的错误记录器。捕获 PDO 错误以显示错误消息没有任何用处,因为无论如何都会将异常转换为文本消息。
-
@Dharman 我认为 PDO 可以一次执行多个查询,假设仿真已开启。