Elasticsearch 8.+ 版本查询方式

1.创建索引

1.2在项目启动后执行,先判断是否有这个索引,没有则创建

java 复制代码
//判断索引是否存在
BooleanResponse troubleShootLog = elasticsearchClient.indices().exists(e -> e.index(TroubleShootLog.INDEX));
java 复制代码
 private void createTroubleShootLogIndex() {
        try {
            elasticsearchClient.indices().create(c -> c
                    .index(TroubleShootLog.INDEX)//索引名称
                    .settings(s->s.numberOfShards(numberOfShards).numberOfReplicas(numberOfReplicas))
                    .mappings(mappings -> mappings  //映射
                            .properties("docPoolId", p -> p
                                    .long_(t -> t)
                            )
                            .properties("poolFileId", p -> p
                                    .long_(t -> t) 
                            )
                            .properties("type", p -> p
                                    .long_(t -> t) 
                            )
                            .properties("opt", p -> p
                                    .integer(t -> t) 
                            )
                            .properties("userId", p -> p
                                    .long_(t -> t) 
                            )
                            .properties("keyword", p -> p
                                    .text(t -> t) 
                            )
                            .properties("aircraftTypes", p -> p
                                    .text(t -> t) 
                            )
                            .properties("docType", p -> p
                                    .text(t -> t) 
                            )
                            .properties("cratedTime", p -> p
                                    .date(t -> t.format("yyyy-MM-dd HH:mm:ss")) //
                            )
                    )
            );
        } catch (IOException e) {
            log.error(e.getMessage(),e);
        }
    }

2.查询

java 复制代码
//创建查询条件,查询text的内容
Query query = builder.bool(b -> b.must(m -> m.matchPhrasePrefix(h -> h.field("text").query(dto.getQ())))).build();
//执行查询
SearchResponse<PdfDoc> pdfDocOne = elasticsearchClient.search(s -> s
                            .index(PdfDoc.INDEX)//要查询的索引名称
                            .query(q -> q.bool(b -> b.must(query)))//查询条件
                            .highlight(setHighLight())//高亮字段
                            .from(dto.getPageNumber())//从第几页开始
                            .size(dto.getPageSize())//到第几页结束
                            .sort(so -> so.field(f -> f//排序
                                    .field("_score").order(SortOrder.Desc)
                                    .field("type").order(SortOrder.Desc)
                                    .field("heat").order(SortOrder.Desc)
                            ))
                    , PdfDoc.class
            );

private Highlight setHighLight() {
        Highlight highlight = Highlight.of(h -> h.preTags("<font color='red'>").postTags("</font>").fields("text", t -> t));
        return highlight;
    }
相关推荐
@月落25 分钟前
alibaba获得店铺的所有商品 API接口
java·大数据·数据库·人工智能·学习
码爸1 小时前
spark读mongodb
大数据·mongodb·spark
WPG大大通1 小时前
有奖直播 | onsemi IPM 助力汽车电气革命及电子化时代冷热管理
大数据·人工智能·汽车·方案·电气·大大通·研讨会
ws2019071 小时前
抓机遇,促发展——2025第十二届广州国际汽车零部件加工技术及汽车模具展览会
大数据·人工智能·汽车
Data-Miner2 小时前
196页满分PPT | 集团流程优化及IT规划项目案例
大数据·数据分析
DolphinScheduler社区2 小时前
怎么办?用DolphinScheduler调度执行复杂的HiveSQL时无法正确识别符号
大数据
goTsHgo2 小时前
Hive自定义函数——简单使用
大数据·hive·hadoop
码爸2 小时前
flink 例子(scala)
大数据·elasticsearch·flink·scala
FLGB2 小时前
Flink 与 Kubernetes (K8s)、YARN 和 Mesos集成对比
大数据·flink·kubernetes