在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中文網其他相關文章!