数据库字符编码与 JDBC 不匹配
在实现跨数据库互操作性时,字符编码兼容性起着至关重要的作用。在此特定场景中,使用 GlassFish 3、JPA 和 MySQL 的 Java Web 应用程序面临字符编码问题。具体来说,使用 JPA 的 update() 方法保存的字符串字段会出现数据损坏,显示“?”而不是某些字符。
尽管服务器、页面和数据库都配置为使用 UTF-8,但罪魁祸首却在其他地方。 决定连接数据库时使用的字符编码的是 JDBC(Java 数据库连接),而不是 JPA。因此,确保 JDBC 连接字符串包含正确的字符编码至关重要。
正如提供的解决方案中所建议的,MySQL 连接字符串的适当语法是:
jdbc:mysql://localhost:3306/administer?characterEncoding=utf8
通过显式指定字符编码在 JDBC 中,连接将使用 UTF-8,它与数据库、服务器和页面编码相匹配。这可确保一致的字符表示,防止数据损坏以及用“?”替换某些字符。
以上是为什么跨数据库互操作场景中我的字符串字段显示'?”而不是字符?的详细内容。更多信息请关注PHP中文网其他相关文章!