【发布时间】:2009-05-13 14:36:42
【问题描述】:
我有一个使用 Hibernate 映射到数据库的 bean。我正在使用 Hibernate Annotations 来指示我想要的映射,并创建索引。彻底简化的代码如下所示。
我遇到的问题是我的 byte[] 字段上的索引没有创建;特别是我的多字段索引 sysUuid 没有被创建(参见示例代码)。在 Hibernate 调试日志中,我什至没有看到创建索引的尝试!
我想指出,uuid 字段上的@Index 注释也不会导致数据库上的索引。
我知道如何使用 MySQL 手动创建索引:
create index sysuuid on persons ( system, `uuid`(8) );
有趣的特点是需要转义 uuid(因为它是 MySQL 函数)并且需要在字段上给出长度(就像文本字段一样)。
但是,我还没有找到使用 Hibernate Annotations 提供索引长度字段的方法,因此我无法测试这是否是问题所在。但是可以肯定的是,在注解中命名字段“uuid(8)”是行不通的。
@Entity
// The UniqueConstraints work
@Table(name = "persons",
uniqueConstraints = {@UniqueConstraint(columnNames = {"uid", "system"}) } )
// but these don't generate an index
@org.hibernate.annotations.Table(appliesTo="persons",
indexes={@Index(name="sysUuid", columnNames={"system", "uuid"}) } )
public class Person {
@Basic
@NotNull
private String uid;
@Basic
private int system;
// Gets mapped to tinyblob
@Basic
@Size(min = 16, max = 16)
private byte[] uuid;
// getters and setters here
}
我想问你的是:是否可以使用注释在 lob 上添加索引,如果可以,如何?
编辑
我确实有可能转向基于字符串的 UUID,但我对此并不满意,因为 uuid 在概念上是一个 16 字节的标识符。
我非常喜欢 Java 类型来匹配问题域。
正如我所说 - 我确实有一个方便的 SQL 语句,因此我可以部署代码 + 一个 SQL 脚本。我只是认为在可行的情况下最好使用自记录代码。
编辑和添加赏金
我相信我需要的索引不能使用 Hibernate Annotations 创建(回复。Matt Solnit 的回答)。
但是,我希望了解更多有关使用 Hibernate Annotations 创建索引的信息,因此最终的答案最终会记录 API。
【问题讨论】: