」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何使用 PDO 檢查行是否存在?

如何使用 PDO 檢查行是否存在?

發佈於2024-11-01
瀏覽:545

How to Check for Row Existence Using PDO?

使用 PDO 檢查行是否存在

您在使用 PDO 驗證資料庫中的行是否存在時遇到了困難。要解決此問題,請考慮以下解決方案:

根據答案中的建議,您可以直接檢查查詢的回傳值。以下是一個例子:

$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';
}

在此程式碼中,$stmt->execute() 嘗試執行查詢。如果沒有找到行,$stmt->fetch() 傳回 FALSE。這允許您使用 if (!$row) 條件來確定該行是否存在。

此外,如果您希望檢查多行或避免獲取該行,您可以使用$stmt-> fetchAll() 方法:

$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);

if (!$rows) {
    echo 'No rows found';
}

或者,您可以指示 MySQL 在找到行時傳回 1:

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

if ($stmt->fetchColumn()) echo 'Row found';

這種方法消除了獲取行的需要,提高了效率。

版本聲明 本文轉載於:1729560796如有侵犯,請聯繫[email protected]刪除
最新教學 更多>

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3