Ralat Sintaks PreparedStatement
Apabila menggunakan Java PreparedStatements, adalah penting untuk memastikan sintaks yang betul untuk mengelakkan ralat. Coretan kod yang disediakan menghadapi ralat sintaks disebabkan kesilapan panggilan kaedah.
Kaedah select1 menerima sql pernyataan yang disediakan dan randNum integer dan cuba melaksanakannya. Walau bagaimanapun, mesej ralat menunjukkan isu sintaks dengan pernyataan SQL:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '?)' at line 1
Isunya terletak pada pernyataan pulangan dalam kaedah select1:
return this.stmt.executeQuery(sql);
Barisan ini cuba untuk dilaksanakan secara salah pernyataan SQL sebagai pernyataan biasa dan bukannya pernyataan yang disediakan. Kaedah yang betul untuk melaksanakan pernyataan yang disediakan ialah executeQuery().
Untuk menyelesaikan ralat, gantikan kod dengan panggilan executeQuery() yang betul:
return this.stmt.executeQuery();
Dikemas kini Kod:
public ResultSet select1(String sql, int randNum) { try { this.stmt = con.prepareStatement(sql); stmt.setInt(1, randNum); return this.stmt.executeQuery(); // Call PreparedStatement.executeQuery } catch (SQLException e) { e.printStackTrace(); return null; } }
Nota:
Sintaks untuk pertanyaan SQL juga mestilah betul. Dalam kes ini, tanda belakang yang hilang di sekitar nilai dalam klausa WHERE telah menyebabkan ralat. Pernyataan SQL yang betul hendaklah:
String selectSql1 = "SELECT `value` FROM `sampling_numbers` WHERE `value` < ?";
Atas ialah kandungan terperinci Mengapa Java PreparedStatement Saya Membuang Ralat Sintaks, dan Bagaimana Saya Boleh Membetulkannya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!