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();
        }

    }
相关推荐
事变天下6 分钟前
数智奔涌,让ICU从“生死门”走向“生命中枢”
大数据
zhojiew6 分钟前
使用 Spark Connect 在 Amazon EMR on EC2 上实现远程 Spark开发
大数据·分布式·spark
跨境卫士苏苏8 分钟前
欧盟固定收费临近轻小件卖家如何判断继续铺量还是收缩
大数据·人工智能·安全·跨境电商·亚马逊
数据皮皮侠9 分钟前
上市公司内源与债权股权融资协同数据(2009-2025)
大数据·人工智能·算法·microsoft·百度
老陈头聊SEO12 分钟前
长尾关键词如何提升SEO效能的实用指南与创新策略
其他·搜索引擎·seo优化
冯RI375II6948735 分钟前
CPC认证是什么。申请CPC认证流程
大数据
青岛前景互联信息技术有限公司1 小时前
企业专职消防队的数字化升级:物联网和大数据的结合
大数据·物联网
杰建云1671 小时前
多门店商城小程序怎么做
大数据·apache
yongyoudayee1 小时前
AI CRM架构深度解析:销售易NeoAgent 2.0如何打破“AI+套壳“的技术困局
大数据·人工智能·架构
SelectDB1 小时前
时间序列近邻关联性能实测:Doris ASOF JOIN 领先 ClickHouse、DuckDB
大数据·数据库·数据分析