MySQL 上有預先準備語句的LIMIT 關鍵字
嘗試使用LIMIT 關鍵字執行預先準備語句時,如果您執行下列操作,則可能會遇到錯誤:使用PDO(PHP 資料物件)庫。這是因為 PDO 將所有參數視為字串,這可能會導致在使用 LIMIT 參數的數值時出現解析錯誤。
要解決此問題,您可以考慮以下選項:
1。一對一綁定參數:
您可以手動將每個參數綁定到適當的類型,確保LIMIT 參數被視為整數:
$comments->bindParam(1, $post, PDO::PARAM_STR); $comments->bindParam(2, $min, PDO::PARAM_INT); $comments->bindParam(3, $min, PDO::PARAM_INT);
2。停用準備好的語句:
另一個選項是停用模擬準備,這可能導致參數被引用:
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, FALSE);
3。不要傳遞LIMIT 值:
您可以將LIMIT 值直接嵌入到查詢字串中,而不是將它們作為參數傳遞:
$query = sprintf('SELECT id, content, date FROM comment WHERE post = ? ORDER BY date DESC LIMIT %d, %d', $min, $max);
透過避免使用模擬準備或明確設定參數類型,可以在MySQL 中成功執行帶有LIMIT 關鍵字的準備語句。
以上是如何在 PDO 中將 LIMIT 與 MySQL 預先準備語句一起使用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!