作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我想使用的索引是枚举类型时,我在使用 Hibernate 搜索时遇到问题。
这是我的应用程序的示例:
@Entity
@Indexed
public class MyEntity{
@Id
@Field
public Long id;
@Field(bridge=@FieldBridge(impl=EnumBridge.class))
public Flavour flavour;
}
与
public enum Flavour {
vanilla,
chocolate,
strawberry,
pistacchio;
}
然后我尝试使用这种类型的查询来查找所有实例。
QueryBuilder qb = [~] ;
Query q = qb.keyword().onField("flavour").matching(Flavour.vanilla).createQuery();
当我测试这个时,结果总是空的。我什至尝试使用 Luke 查看索引的内容,但我似乎没有找到“味道”。提交更改后,我会重新索引所有内容。除枚举字段外,其他所有类型的索引和查询都可以完美运行。
我几乎尝试了norms
、analyze
、index
、store
、... @Field
注释(我正在使用 Hibernate-search 4.5.x 和 hibernate 4.3.1)。
我做错了什么?我应该查看任何设置吗?欢迎任何帮助。
最佳答案
实体似乎使用序号存储 flavor (因此列 flavor 包含 0 而不是“ Vanilla ”)。
我不知道 EnumBridge 在做什么,但我建议将枚举存储为字符串:
@Entity
@Indexed
public class MyEntity{
@Id
@Field
public Long id;
@Field(bridge=@FieldBridge(impl=EnumBridge.class))
@Enumerated(EnumType.STRING)
public Flavour flavour;
}
关于java - 使用 hibernate-search 索引枚举类型字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23056329/
我是一名优秀的程序员,十分优秀!