gpt4 book ai didi

java - 如何使用 Hibernate Annotations 在 Lob/Clob/tinyblob 上添加索引

转载 作者:可可西里 更新时间:2023-11-01 07:33:57 27 4
gpt4 key购买 nike

我有一个使用 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。

最佳答案

您可以使用 Hibernate 的 auxiliary objects 来做到这一点支持,但不能使用注释来完成:-(。

在您的示例中,它看起来像这样(为简洁起见省略了很多内容):

<class name="Person" table="persons">
<!-- whatever -->
<database-object>
<create>create index sysuuid on persons ( system, `uuid`(8) )</create>
<drop>drop index sysuuid</drop>
<dialect-scope name="org.hibernate.dialect.MySQL5InnoDBDialect" />
</database-object>
</class>

对于缺少基于注释的答案,我深表歉意:-(。希望这有帮助。

注意:如果您确实采用这种方法,请注意方言范围必须完全匹配。例如,如果您的 Hibernate 配置说使用 MySQL5InnoDBDialect , 那么你必须在 <dialect-scope> 中有这个方言元素也是如此。使用 MySQLDialect即使它是 InnoDB 方言的父类(super class)也不会工作。

关于java - 如何使用 Hibernate Annotations 在 Lob/Clob/tinyblob 上添加索引,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/858336/

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