首页 > 解决方案 > 列表中的搜索字段 @IndexedEmbedded

问题描述

我有一个实体,它有一个实体列表,我添加@IndexedEmbedded到这个列表中以便能够搜索到它。所以我想搜索所有具有 id 123 且属性 x 等于给定值的实体。我尝试使用下面的代码,但我有这个错误

在 com.xx.xx.AEntity 中找不到字段 bEntity.x

@Entity
@Indexed
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class AEntity implements Serializable {

    private static final long serialVersionUID = 1L;
    
    @Id
    @Field
    private String id;

    @IndexedEmbedded
    @ElementCollection
    private Set<BEntity> bEntity;
    
}


@Entity
@IdClass(BPK.class)
public class BEntity implements Serializable {

    private static final long serialVersionUID = 1L;

    @Id
    @Field(name = "x_number")
    private String x;

    @Id
    @Field(name = "y_number")
    private String y;
    
}

QueryBuilder queryBuilder = getFullTextEntityManager().getSearchFactory().buildQueryBuilder().forEntity(AEntity.class).get();    
Query query = queryBuilder.bool()
            .must(queryBuilder.keyword().onField("id").matching("123").createQuery())
            .must(queryBuilder.keyword().onField("bEntity.x").matching(str).createQuery())
            .createQuery();

标签: javahibernatelucenefull-text-searchhibernate-search

解决方案


你的领域被称为bEntity.x_number,而不是bEntity.x

    @Field(name = "x_number")

这就是您收到此错误的原因。

在您的查询中使用bEntity.x_number而不是,bEntity.x您应该没问题。


推荐阅读