0

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

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

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

Hibernate 数据访问的 JDBC 异常:SQL 的 SQLException [n/a];SQL状态[01000];错误代码[1265];第 1 行的“tipo_via”列的数据被截断;嵌套异常是 org.hibernate.exception.GenericJDBCException:第 1 行的列“tipo_via”的数据被截断

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

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

4

1 回答 1

0

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

于 2013-06-07T19:32:49.650 回答