首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用hibernate JPA,mysql数据库,创建索引错误

使用hibernate JPA,mysql数据库,创建索引错误
EN

Stack Overflow用户
提问于 2014-05-28 06:40:54
回答 2查看 1.6K关注 0票数 1

我使用hibernate JPA

hibernate版本是3.5.1-Final版本,hibernate-annotations版本也是3.5.1-Final版本

mysql版本是:5.5.35-0ubuntu0.12.04.2

我有一个专栏:

代码语言:javascript
复制
@Column(name = "TITLE", length = 300)
@Index(name = "I_PRODUCT_ITEM_TITLE")
public String getTitle() {
    return title;
}

但是创建索引,告诉我

代码语言:javascript
复制
ERROR o.h.tool.hbm2ddl.SchemaUpdate - Unsuccessful: create index I_PRODUCT_ITEM_TITLE on T_PRODUCT_ITEM (TITLE)
ERROR o.h.tool.hbm2ddl.SchemaUpdate - BLOB/TEXT column 'TITLE' used in key specification without a key length

我不知道原因..。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-28 07:00:50

由于指定长度为300,所以Hibernate将列类型设置为TEXT。

在文本列上添加索引需要指定长度前缀,而且Hibernate似乎不能正确地添加索引。

如果你不需要300长度,而且你可以和255生活在一起,那么你就可以做到这一点。

否则,您可以选择使用增量更新脚本创建模式,这是生产系统的首选方法。

您应该创建一个Hibernate JIRA问题来描述这个问题。一些自2005年以来一直在抱怨

票数 1
EN

Stack Overflow用户

发布于 2014-05-28 12:38:18

JPA不提供任何定义或创建indexes.You的特性,只需使用Jpa创建唯一的索引即可。

您可以使用hibernate创建索引。

这个答案可以帮助您使用hibernate创建索引。

定义索引列的Jpa

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23904429

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档