- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个使用 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/
这是我之前问题的跟进:Blob and Storage Requirement 我使用 SHOW TABLE STATUS 进行了一些测试,发现实际使用的总磁盘空间仅取决于上传到数据库的实际文件的大小
如何使字段成为 BLOB 而不是 TINYBLOB? 我的映射如下: private byte[] ImageBytes; public BufferedImage getImage() {
我尝试从数据库 (blob) 中读取图像,但我遇到了问题,因为我不知道图像的 mime 类型。我只有 tinyblob。 我可以读取图像并将其保存回我的硬盘吗? 最佳答案 最好的解决方案是在将图像插入
好吧,我的问题很愚蠢。 在 Hibernate 5.1(5.2 相同)中,我的 Year 列映射到tinyblob,而不是人们所期望的直观的 int 列。其他 JSR-310 列已成功映射。 例如 @
我的附带问题是 tinyblob 和 tinytext 之间真的有什么区别吗? 相信我真正的问题是什么原因,如果有的话,我会选择 varchar(255) 而不是 tinyblob 或 tinytex
对于我正在创建的包含 IP 范围的表,我需要在 MySQL 记录中存储两个 128 位(16 字节)int 值。由于 MySQL 仅支持最多 8 字节的整数,因此我发现我需要使用二进制列 (tinyb
我正在处理一些使用 java8、hibernate5、spring 等的遗留应用程序。我想做的是包含 hibernate-java8 模块以启用 java.time 对象的正确使用,没有任何映射器、转
我有一个使用 Hibernate 映射到数据库的 bean。我正在使用 Hibernate Annotations 来指示我想要的映射,并创建索引。彻底简化的代码如下所示。 我遇到的问题是我的 byt
根据定义: VARCHAR: The range of Length is 1 to 255 characters. VARCHAR values are sorted and compared in
我有一个带有 java.time.Instant 类型的 @Column 的 JPA @Entity。我的理解是这应该映射到 TIMESTAMP 的列类型。但是,Hibernate 自动更新创建了类型
我是一名优秀的程序员,十分优秀!