首頁 >資料庫 >mysql教程 >為什麼我的 PDO 準備的「INSERT INTO」語句不起作用?

為什麼我的 PDO 準備的「INSERT INTO」語句不起作用?

DDD
DDD原創
2025-01-13 07:01:42855瀏覽

Why Doesn't My PDO Prepared `INSERT INTO` Statement Work?

對 MySQL 中 INSERT INTO 的 PDO 準備語句進行故障排除

對 MySQL INSERT INTO 操作使用 PDO 準備語句有時會導致意外結果,例如沒有插入資料。 讓我們檢查一個常見原因及其解決方案。

考慮這段程式碼:

<code class="language-php">$statement = $link->prepare("INSERT INTO testtable(name, lastname, age)
        VALUES('Bob','Desaunois','18')");

$statement->execute();</code>

此程式碼嘗試將新行插入testtable,但通常無法填入資料庫。

缺失的環節:參數綁定

問題在於沒有參數綁定。 雖然準備好的語句增強了針對 SQL 注入的安全性,但它們要求您使用值的佔位符,而不是直接將它們嵌入到查詢中。 這可以實現更安全、更有效率的執行,特別是在使用多組資料執行相同查詢時。

解:命名參數與位置參數

以下是正確實作參數綁定的兩種方法:

1。命名參數:

<code class="language-php">$statement = $link->prepare('INSERT INTO testtable (name, lastname, age)
    VALUES (:fname, :sname, :age)');

$statement->execute([
    ':fname' => 'Bob',
    ':sname' => 'Desaunois',
    ':age' => '18',
]);</code>

這使用命名佔位符(:fname:sname:age),這些佔位符會對應到 execute() 方法陣列中的值。

2。位置參數:

<code class="language-php">$statement = $link->prepare('INSERT INTO testtable (name, lastname, age)
    VALUES (?, ?, ?)');

$statement->execute(['Bob', 'Desaunois', '18']);</code>

它使用問號 (?) 作為佔位符,並在 execute() 方法的陣列中提供對應的值。 這裡的順序至關重要。

這兩種方法都可以有效地綁定參數,防止SQL注入並確保資料插入的可靠。 選擇最適合您的程式設計風格和專案要求的方法。 請記住,在查詢中使用使用者輸入之前,即使使用準備好的語句,也要始終對其進行清理,以保持最佳的安全性。

以上是為什麼我的 PDO 準備的「INSERT INTO」語句不起作用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn