我在将现有项目中的Hibernate Search与数百个实体集成时遇到问题,但至少有一半的实体使用@IdClass注释作为组合键。我可以使用注释@IdClass来解决问题吗?
我也阅读了这篇文章Hibernate search and composed key,但我没有设法解决我的问题。
我有以下示例:
实体类:
@Entity
@Table(name="FAKVS_DB")
@IdClass(value=PK_FAKVS_DB.class)
@Audited
@Indexed
public class FAKVS_DB implements Serializable {
@Id
@Column(name="Key_FAM", length=10, nullable=false)l
private String keyFam;
@Id
@Column(name="Komponentennr", nullable=false)
private Integer komponentenNr;
@Id
@Column(name="Hinweis", nullable=true, length=4)
private String hinweis;
//getters and setters
}
和组合键:
public class PK_FAKVS_DB implements Serializable {
private String keyFam;
private Integer komponentenNr;
private String hinweis;
//getters and setters
}
发生的错误是:
HSEARCH000058: HSEARCH000212: An exception occurred while the MassIndexer was transforming identifiers to Lucene Documents
java.lang.ClassCastException: package.entities.module.fi.pk.PK_FAKVS_DB cannot be cast to java.lang.Integer
at org.hibernate.type.descriptor.java.IntegerTypeDescriptor.unwrap(IntegerTypeDescriptor.java:36)
at org.hibernate.type.descriptor.sql.IntegerTypeDescriptor$1.doBind(IntegerTypeDescriptor.java:63)
at org.hibernate.type.descriptor.sql.BasicBinder.bind(BasicBinder.java:90)
at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:286)
at org.hibernate.type.AbstractStandardBasicType.nullSafeSet(AbstractStandardBasicType.java:281)
at org.hibernate.loader.Loader.bindPositionalParameters(Loader.java:1995)
at org.hibernate.loader.Loader.bindParameterValues(Loader.java:1966)
at org.hibernate.loader.Loader.prepareQueryStatement(Loader.java:1901)
at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:1862)
at org.hibernate.loader.Loader.executeQueryStatement(Loader.java:1839)
at org.hibernate.loader.Loader.doQuery(Loader.java:910)
如果我不能使用@IdClass注释你能告诉我有哪些替代方案吗?
非常感谢你。
答案 0 :(得分:0)
另一种方法是通过Hibernate Search添加一个新属性以用作 Id 。您可以使用@DocumentId
对此进行标记,以使Hibernate搜索引擎将替代属性视为索引中的标识符。
您需要确保这个新属性当然是唯一的;这通常可以通过从真实ID生成String
来完成。您可能希望使用@Transient
注释新的getter,以便它不会在数据库中保留。