【问题标题】:Index Multiple Entities using Hibernate Search使用 Hibernate Search 索引多个实体
【发布时间】:2011-11-20 05:52:29
【问题描述】:

是否可以使用 Hibernate Search 在同一索引中索引多个实体?我有 3 个实体用户、类别和活动。这些实体彼此不相关。

我需要提供一种功能,用户可以在其中搜索这些实体。类似于 facebook 搜索或 Quora 搜索。

例如:https://www.facebook.com/search.php?q=Stackoverflow 将显示具有给定查询字符串的所有组、页面等。

【问题讨论】:

    标签: hibernate search lucene indexing hibernate-search


    【解决方案1】:

    我确实意识到这是一个相当古老的问题,但我仍然会发布这个问题的答案,因为它可能有一天仍然会对某人有所帮助。

    是的,这是可能的。此处描述了如何做到这一点: http://docs.jboss.org/hibernate/search/4.2/reference/en-US/html_single/#section-sharing-indexes

    【讨论】:

    • 不过,对我来说,这是擦除其他实体并仅重新索引我要求重新索引的当前实体。命令ftem.createIndexer().startAndWait(); 正在触发 PurgeAllLuceneWork,然后是重新插入当前实体的流工作。
    【解决方案2】:

    虽然您可以使用 FullTextSession.createFullTextQuery(Query, Class<?> ...) 方法同时查询多个索引,但在同一个索引中索引多个实体是不可能的 (AFAIK)。在你的情况下,用法是fullTextSession.createFullTextQuery(query, User.class, Category.class, Campaign.class);

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-12-29
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-11-27
      • 1970-01-01
      • 2023-04-02
      相关资源
      最近更新 更多