4

我有一个名为的对象MyItemBean,它可以有 0 个或多个关联KeywordBean对象。生成的类如下所示:

@Entity
public class MyItemBean {

   ...stuff...

   @ManyToMany(targetEntity = KeywordBean.class, cascade = CascadeType.PERSIST)
   @JoinTable(name = "tbl_item_keyword", joinColumns = @JoinColumn(name = "item_id"), inverseJoinColumns = @JoinColumn(name = "keyword_id"))
   private List<KeywordBean> keywords = null;

   ...more stuff...
}

@Entity
public class KeywordBean {

   ...stuff...

   private String value=null;

   ...more stuff...
}

我正在使用 JBoss Seam/Hibernate Search 来索引这些对象,以便对它们执行搜索查询。我希望能够搜索MyItemBean具有给定关键字值的实例。然而,这种关系是单向的,因为我将KeywordBean对象应用到的不仅仅是MyItemBean. 我在 Hibernate Search 文档中查看了有关如何索引关系的示例,但它们提供的所有示例都是双向的。谁能告诉我需要应用哪些注释才能MyItemBean.keywords正确索引关键字值?

4

1 回答 1

6

要使用的注释是IndexedEmbedded。它也适用于单向关联。如果您要更改KeywordBean的值,则可能会出现问题Hibernate Search 无法更新引用已更改KeywordBean的MyItemBean实例的索引。在双向关系中,您可以使用@ContainedIn来解决此问题,但您并不真正需要它。在您的用例中提供此索引更新约束可能不是问题。也许您的KeywordBean没有改变。或者,如果它发生变化,您可以重新索引所有手动受影响的 *KeywordBean*s。

——哈代

于 2010-12-20T14:03:54.087 回答