Elasticsearch操作笔记版

news2025/1/6 7:19:15

文章目录

      • 1.ES索引库操作(CRUD)
        • 1.mapping常见属性(前提)
        • 2.创建索引库
        • 3.查询,删除索引库
        • 4.修改索引库
      • 2.ES文档操作(CRUD)
        • 1.新增文档
        • 2.查询、删除文档
          • 查询返回的数据解读:
        • 3.修改文档
      • 3.RestClient操作(索引库/文档)(CRUD)
        • 1.什么是RestClient
        • 2.需要考虑前提条件(mapping的设计)
        • 3.初始化JavaRestClient
        • 4.JavaRestClient(索引库)操作
          • 1.创建索引库
          • 2.删除索引库、判断是否存在
          • OOO索引操作步骤总结
        • 5.JavaRestClient(文档)操作
          • 1.创建文档
          • 2.查询文档
          • 3.更新文档
          • 4.删除文档
          • OOO文档操作步骤总结
          • 5.批量导入数据
      • 4.Elasticsearch搜索功能
        • 1.DSL查询语法
          • 返回的结果解读:
        • 2.全文检索查询(3种)
          • 1.match_all(查询所有)
          • 2.match(推荐)单字段
          • 3.multi_match(多字段)
        • 3.精确查询(2种)
          • 1.term(精确查询)
          • 2.range(范围查询)
        • 4.地理查询(2种)
        • 5.复合查询(2种)
          • 1.相关性算分
            • function score query
          • 2.Boolean Query(4种)
        • 5搜索结果处理
          • 1.排序
          • 2.分页
          • 3.高亮
        • 总结:(4种查询,一种返回)
      • 5.RestClient查询文档
        • 1.match_all
        • 2.match、multi_match
        • 3.term、range
        • 4.复合查询
          • bool query
          • function score query
        • 5.分页和排序
          • 距离排序(地理坐标)
        • 6.高亮highLight
          • 结果解析
          • 代码示例
        • 总结:查询的基本步骤

1.ES索引库操作(CRUD)

1.mapping常见属性(前提)

type地理坐标类型:例如酒店在地图上是一个点就用"type":“geo_point”

2.创建索引库

创建:PUT /索引库名

需要进行分词的属性需要指定分词器,不需要创建索引的属性指定index为false

3.查询,删除索引库

查:GET /索引库名

删:DELETE /索引库名

4.修改索引库

修改:PUT /索引库名/_mapping

只能在原有的基础上添加,无法修改,修改即报错

2.ES文档操作(CRUD)

1.新增文档

POST /索引库名/_doc/文档id

_doc是默认写法

文档id默认是keyword类型,

2.查询、删除文档

查询:GET /索引库名/_doc/文档id

查询返回的数据解读:

_version:版本,主要是指修改了的次数,_source:插入的原始文档

删除:DELETE /索引库名/_doc/文档id

3.修改文档

全量修改:PUT /索引库名/ _doc/文档id

增量修改:POST /索引库名/ _update/文档id

3.RestClient操作(索引库/文档)(CRUD)

1.什么是RestClient

我们重点学习使用Java High Level REST Client(<font style="color:rgb(0, 0, 0);">Java高级REST客户端</font>

2.需要考虑前提条件(mapping的设计)

3.初始化JavaRestClient

<font style="color:#DF2A3F;">注意步骤二</font>

<font style="color:#DF2A3F;">步骤三可以指定多个地址</font>

4.JavaRestClient(索引库)操作
1.创建索引库

MAPPING_TEMPLATE就是mapping创建的语句,这里用常量封装了

2.删除索引库、判断是否存在

用完了也需要销毁client客户端

OOO索引操作步骤总结

5.JavaRestClient(文档)操作
1.创建文档

2.查询文档

最后需要反序列化

3.更新文档

4.删除文档

OOO文档操作步骤总结

5.批量导入数据

就是循环添加多次 IndexRequest(请看创建文档部分)

4.Elasticsearch搜索功能

中文文档:https://docs.kilvn.com/elasticsearch/docs/15.html

1.DSL查询语法

返回的结果解读:

2.全文检索查询(3种)

1.match_all(查询所有)

2.match(推荐)单字段

要把copy_to拷到一个字段

全文检索查询的一种,会对用户输入内容分词,然后去倒排索引库检索

3.multi_match(多字段)

与match查询类似,只不过允许同时查询多个字段

3.精确查询(2种)

1.term(精确查询)

2.range(范围查询)

+e是等于的意思

4.地理查询(2种)

5.复合查询(2种)

复合(compound)查询:复合查询可以将其它简单查询组合起来,实现更复杂的搜索逻辑

1.相关性算分

function score query

weight10分乘以原来的分数就是multiply的加权模式

2.Boolean Query(4种)

must_not / filter不参与算分

5搜索结果处理
1.排序

order是排序的属性,当属性只有一个的时候就可以像图1一样省略不写

2.分页

elasticsearch 默认情况下只返回top10的数据。而如果要查询更多数据就需要修改分页参数了

3.高亮

就是在搜索结果中把搜索关键字突出显示。

搜索字段与高亮字段要一致,不一致添加require_field_match属性

查看返回结果highlight就能看到高亮字段

总结:(4种查询,一种返回)

5.RestClient查询文档

1.match_all

<font style="color:#DF2A3F;">解析结果</font>

代码解析

2.match、multi_match

3.term、range

4.复合查询
bool query

function score query

5.分页和排序

距离排序(地理坐标)

6.高亮highLight

结果解析

代码示例

总结:查询的基本步骤

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2270734.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【狂热算法篇】解锁数据潜能:探秘前沿 LIS 算法

嘿&#xff0c;各位编程爱好者们&#xff01;今天带来的 LIS 算法简直太赞啦 无论你是刚入门的小白&#xff0c;还是经验丰富的大神&#xff0c;都能从这里找到算法的奇妙之处哦&#xff01;这里不仅有清晰易懂的 C 代码实现&#xff0c;还有超详细的算法讲解&#xff0c;让你轻…

【漫话机器学习系列】033.决策树回归(Decision Tree Regression)

决策树回归&#xff08;Decision Tree Regression&#xff09; 决策树回归是一种基于树状结构进行回归分析的监督学习方法。它将输入空间递归地划分为多个区域&#xff0c;并在每个区域内拟合一个简单的常数值&#xff0c;从而对目标变量进行预测。 决策树回归的原理 树的构建…

Vue3中使用 Vue Flow 流程图方法

效果图&#xff1a; 最近项目开发时有一个流程图的功能&#xff0c;需要做流程节点的展示&#xff0c;就搜到了 Vue Flow 这个插件&#xff0c;这个插件总得来说还可以&#xff0c;简单已使用&#xff0c;下边就总结一下使用的方法&#xff1a; Vue Flow官网&#xff1a;https…

ArcGIS JSAPI 高级教程 - 通过RenderNode实现视频融合效果(不借助三方工具)

ArcGIS JSAPI 高级教程 - 通过RenderNode实现视频融合效果(不借助三方工具) 核心代码完整代码在线示例地球中展示视频可以通过替换纹理的方式实现,但是随着摄像头和无人机的流行,需要视频和场景深度融合,简单的实现方式则不能满足需求。 三维视频融合技术将视频资源与三维…

Appllo学习

补充学习: Apollo管理多环境下的配置和踩坑实践 - 简书 Apollo-阿波罗配置中心超详细教程_apllo-CSDN博客 springboot本地local配置覆盖远程Apollo配置&#xff08;含Apollo配置加载顺序说明&#xff09;_本地覆盖apollo配置-CSDN博客 Apollo 配置中心详细教程 - 简书 (包含…

React18路由和Vue3路由进行对比

本文将深入比较 React 18 和 Vue 3 路由的不同之处&#xff0c;帮助你更好地理解如何在这两个框架中进行路由管理。希望能对于从 Vue 3 迁移到 React 的开发者&#xff0c;理解这些差异&#xff0c;帮助你更高效地切换框架和构建应用。 1. 路由配置 React 18 的路由配置 Rea…

Windows系统下载、部署Node.js与npm环境的方法

本文介绍在Windows电脑中&#xff0c;下载、安装并配置Node.js环境与npm包管理工具的方法。 Node.js是一个基于Chrome V8引擎的JavaScript运行时环境&#xff0c;其允许开发者使用JavaScript编写命令行工具和服务器端脚本。而npm&#xff08;Node Package Manager&#xff09;则…

浏览器选中文字样式

效果 学习 Chrome: 支持 ::selection。Firefox: 支持 :-moz-selection 和 ::selection。Safari: 支持 ::selection。Internet Explorer: 支持 :-ms-selection。Microsoft Edge: 支持 ::-ms-selection 和 ::selection。 代码 <!DOCTYPE html> <html lang"en&qu…

指代消解:自然语言处理中的核心任务与技术进展

目录 前言1. 指代消解的基本概念与分类1.1 回指与共指 2. 指代消解的技术方法2.1 端到端指代消解2.2 高阶推理模型2.3 基于BERT的模型 3. 事件共指消解&#xff1a;跨文档的挑战与进展3.1 联合模型3.2 语义嵌入模型&#xff08;EPASE&#xff09; 4. 应用场景与前景展望4.1 关键…

CDPHudi实战-集成spark

[一]使用Spark-shell 1-配置hudi Jar包 [rootcdp73-1 ~]# for i in $(seq 1 6); do scp /opt/software/hudi-1.0.0/packaging/hudi-spark-bundle/target/hudi-spark3.4-bundle_2.12-1.0.0.jar cdp73-$i:/opt/cloudera/parcels/CDH/lib/spark3/jars/; done hudi-spark3.4-bu…

leetcode:面试题 17.01. 不用加号的加法(python3解法)

难度&#xff1a;简单 设计一个函数把两个数字相加。不得使用 或者其他算术运算符。 示例: 输入: a 1, b 1 输出: 2 提示&#xff1a; a, b 均可能是负数或 0结果不会溢出 32 位整数 题解&#xff1a; class Solution:def add(self, a: int, b: int) -> int:sum_list [a…

设计模式 结构型 适配器模式(Adapter Pattern)与 常见技术框架应用 解析

适配器模式&#xff08;Adapter Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许将一个类的接口转换成客户端所期望的另一个接口&#xff0c;从而使原本因接口不兼容而无法一起工作的类能够协同工作。这种设计模式在软件开发中非常有用&#xff0c;尤其是在需要集成…

二维码文件在线管理系统-收费版

需求背景 如果大家想要在网上管理自己的文件&#xff0c;而且需要生成二维码&#xff0c;下面推荐【草料二维码】&#xff0c;这个系统很好。特别适合那些制造业&#xff0c;实体业的使用手册&#xff0c;你可以生成一个二维码&#xff0c;贴在设备上&#xff0c;然后这个二维码…

MySQL8安装与卸载

1.下载mysql MySQL :: Download MySQL Community Serverhttps://dev.mysql.com/downloads/mysql/ 2.解压mysql安装包 解压到自己定义的目录&#xff0c;这里解压就是安装&#xff0c;解压后的路径不要有空格和中文。 3.配置环境变量 配置环境变量可以方便电脑在任何的路径…

数据挖掘——关联规则挖掘

数据挖掘——关联数据挖掘 关联数据挖掘关联规则关联规则挖掘问题&#xff1a;具体挖掘过程Apriori 产生关联规则 关联数据挖掘 关联分析用于发现隐藏在大型数据集中的令人感兴趣的联系&#xff0c;所发现的模式通常用关联规则或频繁项集的形式表示。 关联规则反映一个事物与…

【74HC192减法24/20/72进制】2022-5-17

缘由用74ls192设计一个72进制的减法计数器&#xff0c;需要有逻辑电路图-硬件开发-CSDN问答

Samsung手机首次主要采用竞对Micron LPDDR5内存

根据韩国媒体《韩国先驱报》&#xff08;The Korea Herald&#xff09;的报道&#xff0c;即将在1月底发布的三星 Galaxy S25 系列智能手机将首次主要使用美光科技&#xff08;Micron Technology&#xff09;提供的移动DRAM&#xff0c;而非三星自家的产品。这一消息对于三星的…

Linux驱动开发学习准备(Linux内核源码添加到工程-Workspace)

Linux内核源码添加到VsCode工程 下载Linux-4.9.88源码&#xff1a; 没有处理同名文件的压缩包&#xff1a; https://pan.baidu.com/s/1yjIBXmxG9pwP0aOhW8VAVQ?pwde9cv 已把同名文件中以大写命名的文件加上_2后缀的压缩包&#xff1a; https://pan.baidu.com/s/1RIRRUllYFn2…

leetcode题目(3)

目录 1.加一 2.二进制求和 3.x的平方根 4.爬楼梯 5.颜色分类 6.二叉树的中序遍历 1.加一 https://leetcode.cn/problems/plus-one/ class Solution { public:vector<int> plusOne(vector<int>& digits) {int n digits.size();for(int i n -1;i>0;-…

vue3+Echarts+ts实现甘特图

项目场景&#xff1a; vue3Echartsts实现甘特图;发布任务 代码实现 封装ganttEcharts.vue <template><!-- Echarts 甘特图 --><div ref"progressChart" class"w100 h100"></div> </template> <script lang"ts&qu…