Error: PDO Error: SQLSTATE[HY000]: General error: 2031
此錯誤表示參數有問題SQL 查詢。在這種情況下,問題似乎出在使用 bindValue() 方法手動將 LIMIT 佔位符新增至查詢。
以下程式碼導致錯誤:
<code class="php">if ($limit) { $sth->bindValue(':page', $page - 1, PDO::PARAM_INT); $sth->bindValue(':entries_per_page', $page * $entries_per_page, PDO::PARAM_INT); }</code>
發生該錯誤的原因是查詢包含佔位符(:page 和:entries_per_page),需要使用bindValue() 綁定這些佔位符,然後才能執行查詢。然而,在使用bindValue()綁定LIMIT佔位符之前,引擎會將它們轉換為字串。要解決此問題,您可以使用以下程式碼:
<code class="php">if ($limit) { $query = str_replace(':page', $page - 1, $query); $query = str_replace(':entries_per_page', $page * $entries_per_page, $query); $sth->execute($criteria); }</code>
此程式碼將在執行查詢之前將查詢中的佔位符替換為其值。
小心重複參數名稱
需要注意的是,錯誤 2031 也可能是由於將兩個值綁定到同一參數名稱而引起的。例如:
<code class="php">$sth->bindValue(':colour', 'blue'); $sth->bindValue(':colour', 'red');</code>
使用相同的參數名稱兩次都會導致錯誤。因此,確保每個參數名稱是唯一的非常重要。
以上是什麼可能導致 PDO 中的 SQLSTATE[HY000]: 一般錯誤: 2031?的詳細內容。更多資訊請關注PHP中文網其他相關文章!