首頁 > 資料庫 > mysql教程 > 為什麼我在使用 MySQLPreparedStatements 時會收到''?'附近的語法錯誤”?

為什麼我在使用 MySQLPreparedStatements 時會收到''?'附近的語法錯誤”?

Patricia Arquette
發布: 2024-12-11 12:46:15
原創
638 人瀏覽過

Why Am I Getting a

「?」附近的例外在MySQL中執行PreparedStatement時

在Java中,當使用PreparedStatement執行查詢時,可能會遇到MyorExceptionxErrorException,錯誤編號為1064,表示「?」附近有文法錯誤。即使查詢在具有替換值的 MySQL 查詢瀏覽器中運作,也可能會發生這種情況。

經過仔細檢查,很明顯 MySQL 無法解釋「?」 SQL 查詢中的佔位符,認為其語法無效。這是因為PreparedStatement 尚未取代這些佔位符。

您共享的程式碼片段錯誤地用原始版本覆蓋了準備好的查詢。要修正此問題,請使用PreparedStatement#executeQuery()而不是Statement#executeQuery(String):

PreparedStatement s = conn.prepareStatement(query);
s.setInt(1, intValue);
s.setString(2, strValue);        
rs = s.executeQuery(); // Correct
登入後複製

注意:雖然與目前問題無關,但您的程式碼無法關閉連接、語句和結果集。這種遺漏可能會導致資源耗盡和隨後的應用程式崩潰。透過在finally區塊中關閉這些物件來實現正確的JDBC習慣用法:

try (Connection conn = DriverManager.getConnection(...);
     PreparedStatement s = conn.prepareStatement(...);
     ResultSet rs = s.executeQuery()) {
     // Query execution code
} finally {
     if (rs != null) rs.close();
     if (s != null) s.close();
     if (conn != null) conn.close();
}
登入後複製

以上是為什麼我在使用 MySQLPreparedStatements 時會收到''?'附近的語法錯誤”?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板