检查索引字段是否存在

Check if indexed field exists

我正在尝试将我的应用程序从 hibernate search 5 迁移到 6。我在版本 6 中注意到添加了字段验证,您无法搜索索引中不存在的字段。不幸的是,我有依赖于它的业务逻辑。有没有办法访问 ElasticsearchIndexModel class(据我所知 class 是字段状态)并检查特定字段是否存在?或者有什么办法可以做到这一点?

有个metamodel API.

像这样的东西应该可以工作:

<T> boolean isSearchable(SearchMapping mapping, Class<T> entityClass,
        String fieldPath) {
    SearchIndexedEntity<T> entity = mapping.indexedEntity( entityClass ); 
    IndexDescriptor index = bookEntity.indexManager().descriptor();
    Optional<IndexFieldDescriptor> fieldOptional = index.field(fieldPath)
    if (!fieldOptional.isPresent()) {
        return false;
    }
    IndexFieldDescriptor field = fieldOptional.get();
    return field.isValueField() && field.toValueField().type().searchable();
}

您可以通过以下方式访问 SearchMapping

SearchMapping mapping = Search.mapping( entityManagerFactory ); 

或:

SearchMapping mapping = Search.mapping( entityManager.getEntityManagerFactory() ); 

或者在 Quarkus 中,您可以简单地 have it injected 到您的 bean 中:

public class MyBean {
    @Inject
    SearchMapping mapping;


    ...
}