es最大相似度检索(原生与java客户端)

这篇具有很好参考价值的文章主要介绍了es最大相似度检索(原生与java客户端)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

原生rest:
对“不好”进行分词, "operator": "and"意思是同时满足。

POST corpus_details_22/_search
{
  "query": {
    "dis_max": {
      "queries": [
        {
          "match": {
            "sourceContent": {
              "query": "不好",
              "operator": "and"
            }
          }
        }
      ]
    }
  }
}

结果:

{
  "took" : 0,
  "timed_out" : false,
  "_shards" : {
    "total" : 1,
    "successful" : 1,
    "skipped" : 0,
    "failed" : 0
  },
  "hits" : {
    "total" : {
      "value" : 3,
      "relation" : "eq"
    },
    "max_score" : 2.4820914,
    "hits" : [
      {
        "_index" : "corpus_details_22",
        "_type" : "_doc",
        "_id" : "gqYAxYMBXTGsShgCkhpA",
        "_score" : 2.4820914,
        "_source" : {
          "targetContent" : "haobuhao .",
          "sourceContent" : "好不好。",
          "realmCode" : 0,
          "sourceLanguageId" : 1,
          "corpusScore" : 1,
          "id" : 5,
          "targetLanguageId" : 2
        }
      },
      {
        "_index" : "corpus_details_22",
        "_type" : "_doc",
        "_id" : "g6YAxYMBXTGsShgCkhqB",
        "_score" : 2.2032433,
        "_source" : {
          "targetContent" : "nibuhao .",
          "sourceContent" : "你不好。",
          "realmCode" : 0,
          "sourceLanguageId" : 1,
          "corpusScore" : 0.4,
          "id" : 6,
          "targetLanguageId" : 2
        }
      },
      {
        "_index" : "corpus_details_22",
        "_type" : "_doc",
        "_id" : "gKYAxYMBXTGsShgCkRq5",
        "_score" : 1.9686708,
        "_source" : {
          "targetContent" : "not very good .",
          "sourceContent" : "不怎么好。",
          "realmCode" : 0,
          "sourceLanguageId" : 1,
          "corpusScore" : 1,
          "id" : 3,
          "targetLanguageId" : 2
        }
      }
    ]
  }
}

java RestHighLevelClient文章来源地址https://www.toymoban.com/news/detail-512975.html

public CorpusDetailsLikesVo getLikesData(String indexName, String target) throws IOException {
    RestHighLevelClient client = RestHighLevelClientPoolUtil.getClient();

    SearchRequest request = new SearchRequest(indexName);
    SearchSourceBuilder builder = new SearchSourceBuilder();

    DisMaxQueryBuilder disMaxQuery = QueryBuilders.disMaxQuery();

    // 复合查询
    disMaxQuery.innerQueries().add(
            QueryBuilders.matchQuery(
                    "sourceContent", target
            ).operator(Operator.AND)
    );

    // 组装查询条件
    builder.query(disMaxQuery);

    // 返回数据
    request.source(builder);
    SearchResponse response = client.search(request, RequestOptions.DEFAULT);

    for (SearchHit hit : response.getHits().getHits()) {
        Map<String, Object> sourceAsMap = hit.getSourceAsMap();
        if (!sourceAsMap.isEmpty()) {
            Object res = BeanUtil.mapToBean(sourceAsMap, Object.class, false);
        }
    }
    client.close();
}

到了这里,关于es最大相似度检索(原生与java客户端)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【已解决】Java 中使用 ES 高级客户端库 RestHighLevelClient 清理百万级规模历史数据

    🎉工作中遇到这样一个需求场景:由于ES数据库中历史数据过多,占用太多的磁盘空间,需要定期地进行清理,在一定程度上可以释放磁盘空间,减轻磁盘空间压力。 🎈在经过调研之后发现,某服务项目每周产生的数据量已经达到千万级别,单日将近能产生 两百万 的数据量

    2024年02月14日
    浏览(44)
  • es相关的官方客户端与spring客户端对比与介绍

    es提供的 TransportClient 传统的客户端,基于TCP传输协议与Elasticsearch通信。 已经被弃用,不推荐使用。 适用于Elasticsearch 5.x及以前的版本 因为Elasticsearch 6.x及以上版本已不再支持TCP Transport协议,TransportClient无法连接Elasticsearch集群。 RestHighLevelClient 是一个高级的REST客户端,主要用于与

    2024年02月02日
    浏览(66)
  • Scala连接ES客户端

    大家好,我是楚生辉,在未来的日子里我们一起来学习大数据相关的技术,一起努力奋斗,遇见更好的自己! 本文详细的介绍了如何使用Scala语言连接上Elasticsearch客户端,有需要的小伙伴可以自行获取与学习~ 使用方法 写入ES中,就要规划,是写入到一个索引中,还是分割索

    2024年01月21日
    浏览(52)
  • ES客户端RestHighLevelClient的使用

    默认情况下,ElasticSearch使用两个端口来监听外部TCP流量。 9200端口:用于所有通过HTTP协议进行的API调用。包括搜索、聚合、监控、以及其他任何使用HTTP协议的请求。所有的客户端库都会使用该端口与ElasticSearch进行交互。 9300端口:是一个自定义的二进制协议,用于集群中各

    2024年02月03日
    浏览(59)
  • 【ES实战】ES创建Transports客户端时间过长分析

    2023年10月19日 在创建ES Transport客户端的时,当出现以下场景时,影响连接速度。 使用ES Transport 客户端创建与集群的链接。 连接地址里面有不存在的IP 在增加ES节点时,采用逐个增加的方式 整个建立链接的过程会非常耗时。 采用jar依赖如下 创建连接代码如下 输出结果 是否可

    2024年02月07日
    浏览(45)
  • ES查询客户端初始化(RestHighLevelClient)

    另外,如果说把es当成一个数据库使用,可以看下开源项目easy-es,操作更方便。文档地址:快速开始 | Easy-Es

    2024年02月11日
    浏览(51)
  • 袁庭新ES系列15节|Elasticsearch客户端基础操作

    上一章节我们介绍了搭建Elasticsearch集群相关的知识。那么又该如何来操作Elasticsearch集群呢?在ES官网中提供了各种语言的客户端,我们在项目开发过程中有多种Elasticsearch版本和连接客户端可以选择,那么他们有什么区别?这一章节袁老师带领大家来学习Elasticsearch客户端相关

    2024年04月25日
    浏览(48)
  • Redis的Java客户端-Java客户端以及SpringDataRedis的介绍与使用

    Spring Data Redis底层支持同时兼容Jedis和Lettuce两种不同的Redis客户端,可以根据需要任意选择使用其中的一种。这样既可以保留现有代码使用的Jedis方式,也可以通过使用基于Netty的高性能Lettuce客户端,提升应用的性能和吞吐量。 Jedis是一个传统的Java Redis客户端,使用BIO进行So

    2024年02月08日
    浏览(61)
  • [AJAX]原生AJAX——服务端如何发出JSON格式响应,客户端如何处理接收JSON格式响应

    服务端代码: 主要代码 // 第一步:设置发给客户端的JSON格式数据     var data={         code:200,         msg:\\\"成功\\\"     }     // 第二步:由于response.send()只能发送字符串,所以要把JSON转换成字符串     data = JSON.stringify(data)     // 第三步:发送数据     response.send(data); 根据上

    2024年02月13日
    浏览(50)
  • es(Elasticsearch)客户端Elasticsearch-head安装使用(04Elasticsearch-head安装篇)

    elasticsearch-head是一款专门针对于elasticsearch的客户端工具,用来展示数据。elasticsearch-head是基于JavaScript语言编写的,可以使用npm部署,npm是Nodejs下的包管理器 安裝方式利用npm和nodejs进行安装启动,github中给出的安装方法也是这种,本文就是以这种方式进行解说 es(Elasticsearc

    2024年01月17日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包