Obtention du SQL réel exécuté par un PreparedStatement
Dans la programmation Java, on rencontre une méthode utilitaire courante qui ouvre une connexion à une base de données, construit un PreparedStatement, l'exécute et renvoie un jeu de résultats. À des fins de débogage, la journalisation de l'instruction SQL réelle qui a été exécutée serait bénéfique, mais la simple journalisation du modèle SQL d'origine (avec des espaces réservés) n'est pas suffisante.
Impossible d'obtenir le SQL de PreparedStatement
Malheureusement, en raison de la nature des instructions préparées, il n'existe aucun moyen de récupérer la requête SQL réelle qui sera exécutée. Les instructions préparées sont divisées en deux composants : l'instruction elle-même (avec des espaces réservés) et les variables liées. Le serveur de base de données analyse et analyse l'instruction, et les variables liées sont utilisées pour exécuter l'instruction. Cependant, aucune reconstruction de la requête SQL réelle n'a lieu ni côté Java ni côté base de données.
Alternatives de débogage
À des fins de débogage, il existe deux solutions alternatives :
Exemple
Considérons une déclaration avec des espaces réservés :
SELECT * FROM USERS WHERE ID = ?
Et relié variable :
int userId = 123;
La requête SQL manuelle serait :
SELECT * FROM USERS WHERE ID = 123
Qui serait ensuite enregistrée à des fins de débogage.
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!