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;
    }
相关推荐
秃头菜狗1 小时前
八、安装 Hadoop
大数据·hadoop·分布式
毕设源码-郭学长8 小时前
【开题答辩全过程】以 Python基于大数据的四川旅游景点数据分析与可视化为例,包含答辩的问题和答案
大数据·python·数据分析
顧棟8 小时前
【HDFS实战】HADOOP 机架感知能力-HDFS
大数据·hadoop·hdfs
在未来等你10 小时前
Elasticsearch面试精讲 Day 23:安全认证与权限控制
elasticsearch· 面试· 安全认证· 权限控制· x-pack security· rbac· ldap
斯普信专业组10 小时前
Filebeat写ElasticSearch故障排查思路(上)
运维·elasticsearch·中间件·filebeat
程序员果子11 小时前
Kafka 深度剖析:架构演进、核心概念与设计精髓
大数据·运维·分布式·中间件·架构·kafka
Elasticsearch11 小时前
如何在 vscode 里配置 MCP 并连接到 Elasticsearch
elasticsearch
在钱塘江11 小时前
Elasticsearch 快速入门 - Python版本
后端·python·elasticsearch
isfox12 小时前
Hadoop RPC深度解析:分布式通信的核心机制
大数据
猎板PCB黄浩12 小时前
PCB 半固化片:被忽视的成本控制关键,猎板的技术选型与安全适配策略
大数据·网络·人工智能