Maison > base de données > tutoriel mysql > Pourquoi mon Java PreparedStatement génère-t-il une erreur de syntaxe et comment puis-je la corriger ?

Pourquoi mon Java PreparedStatement génère-t-il une erreur de syntaxe et comment puis-je la corriger ?

DDD
Libérer: 2024-11-28 21:46:13
original
627 Les gens l'ont consulté

Why Does My Java PreparedStatement Throw a Syntax Error, and How Can I Fix It?

Erreur de syntaxe de PreparedStatement

Lors de l'utilisation de Java PreparedStatements, il est crucial de garantir une syntaxe correcte pour éviter les erreurs. L'extrait de code fourni rencontre une erreur de syntaxe en raison d'un appel de méthode erroné.

La méthode select1 reçoit une instruction SQL préparée et un randNum entier et tente de l'exécuter. Cependant, le message d'erreur indique un problème de syntaxe avec l'instruction 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
Copier après la connexion

Le problème réside dans l'instruction return dans la méthode select1 :

return this.stmt.executeQuery(sql);
Copier après la connexion

Cette ligne tente d'exécuter de manière incorrecte l'instruction SQL comme une instruction normale au lieu d'une instruction préparée. La méthode correcte pour exécuter une instruction préparée est executeQuery().

Pour résoudre l'erreur, remplacez le code par l'appel executeQuery() correct :

return this.stmt.executeQuery();
Copier après la connexion

Code mis à jour :

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;
    }
}
Copier après la connexion

Remarque :

La syntaxe de la requête SQL doit être également correct. Dans ce cas, les backticks manquants autour de la valeur dans la clause WHERE étaient à l'origine de l'erreur. L'instruction SQL correcte doit être :

String selectSql1 = "SELECT `value` FROM `sampling_numbers` WHERE `value` < ?";
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal