使用 PDO 检查行是否存在
您在使用 PDO 验证数据库中的行是否存在时遇到了困难。要解决此问题,请考虑以下解决方案:
根据答案中的建议,您可以直接检查查询的返回值。下面是一个示例:
<code class="php">$stmt = $conn->prepare('SELECT * FROM table WHERE ID=?'); $stmt->bindParam(1, $_GET['id'], PDO::PARAM_INT); $stmt->execute(); $row = $stmt->fetch(PDO::FETCH_ASSOC); if (!$row) { echo 'Row does not exist'; }</code>
在此代码中,$stmt->execute() 尝试执行查询。如果没有找到行,$stmt->fetch() 返回 FALSE。这允许您使用 if (!$row) 条件来确定该行是否存在。
此外,如果您希望检查多行或避免获取该行,您可以使用 $stmt-> ;fetchAll() 方法:
<code class="php">$rows = $stmt->fetchAll(PDO::FETCH_ASSOC); if (!$rows) { echo 'No rows found'; }</code>
或者,您可以指示 MySQL 在找到行时返回 1:
<code class="php">$sql = 'SELECT 1 from table WHERE id = ? LIMIT 1'; $stmt = $conn->prepare($sql); $stmt->execute([$_GET['id']]); if ($stmt->fetchColumn()) echo 'Row found';</code>
这种方法消除了获取行的需要,提高效率。
以上是如何使用 PDO 检查行是否存在?的详细内容。更多信息请关注PHP中文网其他相关文章!