首页 > 后端开发 > php教程 > 如何使用 PDO 检查数据库中行是否存在?

如何使用 PDO 检查数据库中行是否存在?

Susan Sarandon
发布: 2024-10-22 10:32:02
原创
1002 人浏览过

How Can You Check the Existence of a Row in a Database Using PDO?

如何使用 PDO 检查数据库中的行是否存在

当尝试执行以数据库中不存在特定行为条件的操作时数据库中,使用 count($row) == 0 或 if($stmt->rowCount()

更有效的方法是直接检查查询的返回值。以下代码片段说明了此技术:

<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 'nothing found';
}</code>
登录后复制

如果该行存在于数据库中,此方法将返回 true,如果不存在,则返回 false。

用于检查多行是否存在,您可以使用 fetchAll() 方法:

<code class="php">$rows = $stmt->fetchAll(PDO::FETCH_ASSOC); // Same here
if( ! $rows)
{
    echo 'nothing found';
}</code>
登录后复制

在您希望避免获取数据的情况下,您可以使用以下查询将 MySQL 配置为返回布尔值:

<code class="php">$sql = 'SELECT 1 from table WHERE id = ? LIMIT 1';
$stmt = $conn->prepare($sql);
$stmt->execute([$_GET['id']]);

if($stmt->fetchColumn()) echo 'found';</code>
登录后复制

如果该行存在于数据库中,此方法将返回非零值,否则返回 false。

以上是如何使用 PDO 检查数据库中行是否存在?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板