跨越两个没有嵌入索引的实体进行休眠搜索

问题描述 投票:0回答:1

我正在尝试使用Hibernate Search 6和Elastic Search我尝试构建的一个简单示例如下。

我有一个Book实体,它具有类似titleauthorNamegenreprice的信息我有一个Shop实体,该实体的信息类似shopNamephoneemaillocation我有一个“联接表”,可以在角落和商店之间进行多对多映射。 (一本书可以在许多商店中,而一家商店可以有很多书籍)

我正在尝试通过名称和位置进行搜索,理想情况下是在离输入内容最近的位置查找一本书。文档中的标准书籍作者示例需要IndexedEmbedded批注,在我的情况下这实际上是不可能的,因为我正在使用联接表。是否有解决此问题的替代方法

elasticsearch hibernate-search quarkus
1个回答
0
投票

我的实体

    @Indexed
    public class Book extends PanacheEntity{
      public String title;
      public String authorName;  
    @OneToMany(mappedBy = "book", fetch = FetchType.LAZY, cascade = { CascadeType.REMOVE })
      public List<BookShopRelation> bookShopRelation = new ArrayList<>();
    }  


    @Indexed
    public class Shop extends PanacheEntity{
      public String name;
      public String city;  
      @OneToMany(mappedBy = "shop", fetch = FetchType.LAZY, cascade = { CascadeType.REMOVE })
      private List<BookShopRelation> bookShopRelation = new ArrayList<>();
    }

    @Indexed
    public class BookShopRelation extends PanacheEntity{
    @JoinColumn(name = "shop_id")
        @ManyToOne(fetch = FetchType.EAGER, optional = false)
        @IndexedEmbedded
        private Shop shop;

        @JoinColumn(name = "offer_id")
        @ManyToOne(fetch = FetchType.EAGER, optional = false)
        @IndexedEmbedded
        private Book book;
    }   

对我来说,关键是要理解,关系表可以被索引并用作搜索的基础

 List<BookShopRelation> result = Search.session(entityManager)
                .search(BookShopRelation.class) .predicate(f ->
                        pattern == null || pattern.trim().isEmpty() ?
                                f.matchAll() : 
                                f.simpleQueryString()
                                    .fields("book.title").matching(pattern) 
                    ) 
                    .fetchHits(size.orElse(20));
© www.soinside.com 2019 - 2024. All rights reserved.