Maison > Java > javaDidacticiel > Comment obtenir le SQL réel exécuté par un PreparedStatement en Java ?

Comment obtenir le SQL réel exécuté par un PreparedStatement en Java ?

Patricia Arquette
Libérer: 2024-11-11 08:42:02
original
560 Les gens l'ont consulté

How to Get the Actual SQL Executed by a PreparedStatement in Java?

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 :

  1. Code de déclaration de sortie : Enregistrez le code de déclaration avec des espaces réservés et la liste des liens liés variables.
  2. Créer une requête SQL manuelle : Construisez une requête SQL manuellement en combinant le code de l'instruction avec les valeurs des variables liées.

Exemple

Considérons une déclaration avec des espaces réservés :

SELECT * FROM USERS WHERE ID = ?
Copier après la connexion

Et relié variable :

int userId = 123;
Copier après la connexion

La requête SQL manuelle serait :

SELECT * FROM USERS WHERE ID = 123
Copier après la connexion

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!

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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal