Problème d'encodage UTF-8 avec Java et MySQL
Lorsque vous travaillez avec Java et MySQL, il est essentiel de garantir un encodage UTF-8 approprié pour évitez les problèmes de stockage des personnages. Voici comment résoudre un problème courant où les caractères spéciaux sont stockés sous forme de points d'interrogation dans la base de données :
Problème :
Utilisation de la méthode createStatement et l'exécution de requêtes SQL impliquant des caractères spéciaux entraîne le stockage des caractères sous forme de points d'interrogation. Par exemple, des caractères étendus tels que "מסירות קצרות" peuvent apparaître comme "???????".
Réponse :
Le problème provient de l'absence d'Unicode et paramètres d'encodage des caractères lors de l'établissement de la connexion avec MySQL. Pour résoudre ce problème, ajoutez les paramètres suivants lors de la création de la connexion :
<code class="java">con = DriverManager.getConnection("jdbc:mysql:///dbname?useUnicode=true&characterEncoding=utf-8", "user", "pass");</code>
Cela garantit que la connexion utilise le codage Unicode et le jeu de caractères spécifié (dans ce cas, UTF-8) pour la représentation des caractères. En définissant ces paramètres, MySQL peut gérer et stocker correctement les caractères spéciaux.
Conseils supplémentaires :
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!