Heim > Java > javaLernprogramm > Warum wirft mein PreparedStatement in Java einen MySQL-Syntaxfehler in der Nähe von „?' aus?

Warum wirft mein PreparedStatement in Java einen MySQL-Syntaxfehler in der Nähe von „?' aus?

Linda Hamilton
Freigeben: 2025-01-01 02:31:09
Original
175 Leute haben es durchsucht

Why Does My PreparedStatement in Java Throw a MySQL Syntax Error Near

MySQL-Syntaxfehler bei PreparedStatement-Frage

Beim Versuch, eine Abfrage mit PreparedStatement in Java auszuführen, tritt ein Fehler auf, der auf einen Syntaxfehler in der Nähe von „?“ hinweist. Die Ausnahme ist:

com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: 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 '? or MemberName = ?' at line 1
Nach dem Login kopieren

Code-Snippet

String query = "select MemberID, MemberName from members where MemberID = ? or MemberName = ?";
Connection conn = DriverManager.getConnection(DATABASE_URL, USERNAME, PASSWORD);
PreparedStatement s = conn.prepareStatement(query);
s.setInt(1, 2);
s.setString(2, "zen");
ResultSet rs = s.executeQuery(query); // Fail!
Nach dem Login kopieren

Problemlösung

Der Fehler tritt auf, weil MySQL das „?“ nicht erkennt. in der SQL-Abfrage als Platzhalter. Dies ist auf den folgenden Aufruf zurückzuführen:

rs = s.executeQuery(query); // Fail!
Nach dem Login kopieren

Anstatt PreparedStatement#executeQuery ohne Argumente zu verwenden, wird die ursprüngliche Abfragezeichenfolge übergeben, die die vorbereitete Anweisung überschreibt.

Um das Problem zu beheben , dieexecuteQuery-Methode von PreparedStatement sollte ohne Argumente aufgerufen werden:

rs = s.executeQuery(); // OK!
Nach dem Login kopieren

Resource Leckage

Obwohl es nichts mit dem ursprünglichen Problem zu tun hat, verliert der Code Ressourcen. Um dies zu verhindern, sollten Ressourcen mit der JDBC-Sprache geschlossen werden:

try {
    // Acquire resources here
} catch (Exception e) {
    // Handle exception
} finally {
    // Close resources here
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWarum wirft mein PreparedStatement in Java einen MySQL-Syntaxfehler in der Nähe von „?' aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage