gpt4 book ai didi

java - Hibernate hbm2ddl.auto=validate 和 MySQL 文本类型的问题

转载 作者:可可西里 更新时间:2023-11-01 06:43:17 26 4
gpt4 key购买 nike

我尝试在我继承的项目上启用 hbm2ddl.auto=validate。我现在收到很多关于使用文本或 mediumtext(MySQL 数据库)映射的字符串属性的错误列类型异常。

映射是:

@Column(name = "DESCRIPTION", nullable = false, length = 65535)
@Length(max = 65535)
@NotNull
public String getDescription() {
return this.description;
}

数据库中的数据类型是“文本”(utf8_general_ci)。

我认为这应该是正确的映射,但 Hibernate 提示它找到了文本,但期待的是长文本。

我检查了 hibernate 配置,但没有指定对话框。我已经添加了

<property name="hibernate.dialect" value="org.hibernate.dialect.MySQLInnoDBDialect"/>

但这似乎并没有什么不同。

我知道我可以将 columnDefinition="text"添加到映射中,但我必须在很多地方这样做,恕我直言,映射应该已经正确了。那么出了什么问题呢?有什么想法吗?

谢谢

最佳答案

您必须将 columnDefinition 添加到 @Column 注释中,如下所示:

@Column(name = "DESCRIPTION", nullable = false, length = 65535, columnDefinition="TEXT")

关于java - Hibernate hbm2ddl.auto=validate 和 MySQL 文本类型的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5952783/

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