elasticsearch-java-api 8.10.X使用示例

1.获取 ElasticsearchClient 实例 具体操作参考本人之前的文章 spring boot3.2 集成 es 8.x 版本工具类 支持认证与非认证的方式( jdk21)-CSDN博客

2.Query DSL 使用样例如下

java 复制代码
 public void testhttps() {

        String host = "17X.20.5X.XXX";

        int port = XXX;

        String login = "xxx";

        String password = "xxx@123";

        // Create the transport and the API client
        EsRestClientUtil esRestClientUtil = EsRestClientUtil.getInstance();
        try (esRestClientUtil) {
            var esClient = esRestClientUtil.getElasticsearchHttpClient(host, port, login, password);
            JSONObject condition = JSONObject.of("xm.keyword", "张柳");
            JSONObject condition1 = JSONObject.of("gmsfhm.keyword", "610102190012120016");
            List<JSONObject> esCondition = new ArrayList<>();
            List<Query> queries = new ArrayList<>();
            condition1.forEach((k, v) -> {
                Query byName = MatchQuery.of(m -> m
                        .field(k)
                        .query(v.toString())
                )._toQuery();
                queries.add(byName);
            });
            // 模糊查询  支持如下四种格式
            // Changing a character (box → fox)
            //Removing a character (black → lack)
            //Inserting a character (sic → sick)
            //Transposing two adjacent characters (act → cat)
            Query fquzzy = FuzzyQuery.of(fq-> fq.field("user").value("suer1").fuzziness("AUTO"))._toQuery();
            // 年龄段查询示例
            Query rksj = RangeQuery.of(mq -> mq.field("age").gt(JsonData.of("18")).lte(JsonData.of("40")))._toQuery();
            Query rksj1 = RangeQuery.of(mq -> mq.field("rksj").gt(JsonData.of("2020-10-15 14:28:10")).lte(JsonData.of("2022-10-15 14:38:14")).format("yyyy-MM-dd HH:mm:ss"))._toQuery();
            // text 类型的时间范围查询示例
            Query rksj2 = RangeQuery.of(mq -> mq.field("gxsj.keyword").gt(JsonData.of("2020-10-15 14:28:10")).lte(JsonData.of("2022-10-15 14:38:14")))._toQuery();
            // termQuery 写法    类比SQl  =
            Query termQuery = TermQuery.of(mq -> mq.field("xm.keyword").value("王五"))._toQuery();
            // TermsQuery 写法  类比SQL  in
            List<FieldValue> fieldValues = new ArrayList<>();
            fieldValues.add(FieldValue.of("张柳"));
            fieldValues.add(FieldValue.of("王五"));
            Query query = TermsQuery.of(mq -> mq.field("xm.keyword").terms(ts -> ts.value(fieldValues)))._toQuery();
            Query query1 = TermsQuery.of(mq -> mq.field("xm.keyword").terms(ts -> ts.value(List.of(FieldValue.of("张柳"),FieldValue.of("王五")))))._toQuery();
            queries.add(termQuery);
            SearchResponse<JSONObject> response = esClient.search(es -> es
                            .index("ads_tag_rk_dd")
                            .query(q -> q
                                    .bool(b -> b
//                                            .should(s-> s.bool(b1 -> b1.must(b2->b2.bool(s2->s2.should(queries))).must(termQuery)))
                                            .must(fquzzy)
//                                            .must(rksj1)
//                                            .must(rksj2)
//                                            .must(termQuery)
//                                            .


                                    )

                            )
                            // 排序写法
                            .sort(SortOptions.of(so->so.field(FieldSort.of(fs -> fs.field("rksj").order(SortOrder.Desc)))))
                            .from(0)
                            .size(3),
                    JSONObject.class);
            List<Hit<JSONObject>> hits = response.hits().hits();
            for (Hit<JSONObject> hit : hits) {
                JSONObject product = hit.source();
                esCondition.add(product);
            }
            log.info("数据为{}",esCondition);
            log.info("总数为{}",response.hits().total().value());
        } catch (Exception e) {e.printStackTrace();
        }

    }
相关推荐
Dxy12393102161 小时前
Elasticsearch 索引与映射:为你的数据打造一个“智能仓库”
大数据·elasticsearch·搜索引擎
岁岁种桃花儿2 小时前
Kafka从入门到上天系列第一篇:kafka的安装和启动
大数据·中间件·kafka
Apache Flink2 小时前
Apache Flink Agents 0.2.0 发布公告
大数据·flink·apache
永霖光电_UVLED2 小时前
打造更优异的 UVB 激光器
大数据·制造·量子计算
m0_466525293 小时前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
晟诺数字人3 小时前
2026年海外直播变革:数字人如何改变游戏规则
大数据·人工智能·产品运营
vx_biyesheji00013 小时前
豆瓣电影推荐系统 | Python Django 协同过滤 Echarts可视化 深度学习 大数据 毕业设计源码
大数据·爬虫·python·深度学习·django·毕业设计·echarts
2501_943695333 小时前
高职大数据与会计专业,考CDA证后能转纯数据分析岗吗?
大数据·数据挖掘·数据分析
实时数据3 小时前
通过大数据的深度分析与精准营销策略,企业能够有效实现精准引流
大数据
子榆.4 小时前
CANN 性能分析与调优实战:使用 msprof 定位瓶颈,榨干硬件每一分算力
大数据·网络·人工智能