gpt4 book ai didi

java - 插入行 SPRING + Hibernate 时的 MySql 编码问题

转载 作者:行者123 更新时间:2023-11-30 01:35:16 25 4
gpt4 key购买 nike

我的最后一年项目遇到问题。我正在使用 Spring + Hibernate 访问我的 MySql DB。我使用 Tapestry 作为 View 层。

我需要插入一行,其中一个字段与枚举字段匹配。枚举值之一是“Polígono”。我的数据库编码设置为 UTF-8。

我将数据库转储到一个 XML 文件(自定义格式)中并进行解析。目的是通过这个 XML 文件在不同的设备上创建数据库。我删除了测试数据库并尝试从 XML 文件恢复它。单词“Polígono”按其在文件上的样子显示(UTF-8 编码),但如果我尝试使用我的服务和 DAO 插入它,我会得到这个(tipo_via 是我试图在其中插入的 DB 列)插入该值):

JDBC exception on Hibernate data access: SQLException for SQL [n/a]; SQL state [01000]; error code [1265]; Data truncated for column 'tipo_via' at row 1; nested exception is org.hibernate.exception.GenericJDBCException: Data truncated for column 'tipo_via' at row 1

如果我打印从 XML 中读取的内容(我试图分配给行字段的字符串),我会在控制台上看到以下内容:PolÝgono如果我创建一个具有“Polígono”值的字符串并打印它,我会在控制台上得到:PolÝgono

有人知道如何解决这个问题吗?这很奇怪。提前致谢

最佳答案

问题已解决。我认为我编写用于创建数据库的 SQL 脚本的文件不是 UTF8 编码。我使用 DB GUI 管理器 (SQLYog) 检查了该字段的枚举值,并检查了这些值的编码是否错误。我修复了它,问题就消失了!

关于java - 插入行 SPRING + Hibernate 时的 MySql 编码问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16989666/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com