码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • es分布式全文搜索引擎介绍、下载和安装、索引操作、文档操作


    目录

    一 介绍

    二 下载

     三 开启服务端

    四 索引操作

    4.1 不使用分词器创建索引

     4.2 查询索引

    4.3 删除索引

    *4.4 使用分词器创建索引

    五 文档操作(数据操作)

    六 SpringBoot整合ES

    6.1 未使用分词器的整合

     6.2 使用分词器整合

     6.3 添加文档​编辑

     6.4 查询文档


    一 介绍

    Elasticsearch 是一个分布式全文搜索引擎,简称es


    全文搜索过程:
    分词 → 通过分词查到数据的ID → 通过id得到部分数据

    特征:
    1 倒排索引:由数据到ID
    2 要想用全文搜索技术,需要先创建文档,,再使用文档

    二 下载

    官方下载地址:

     Elasticsearch 7.16.2 | Elastic

    (我运行最新的8版本有问题,后来使用7.16版本就没有问题) 

    链接:https://pan.baidu.com/s/1joFKYSMtCK8nr3UWnwrh-w 
    提取码:0629 
     

    默认提供了一个jdk17的版本

     三 开启服务端

     

     

     有两个端口9300和9200,其中9200是对外提供服务的端口

     能访问到9200

    四 索引操作

    在postman里操作

    4.1 不使用分词器创建索引

    put

    创建books的索引

     4.2 查询索引

    get

     查询books的索引

    4.3 删除索引

    delete

    删除books的索引

    *4.4 使用分词器创建索引

    分词:就是把一条数据提取出不同的搜索关键字,方便检索的时候 根据分出的关键字 就能检索到这条数据

    打开es的plugins文件夹,在下面创建ik文件夹: 把下载的分词器解压放在这里

     分词器插件放好后,需要重新启动es服务端

    使用分词器创建索引

     body里添加的完整json数据如下图:

    其中id 和 type属性类型是keyword,直接是关键字,直接检索id/type就能找到这条数据

    其中name和description属性类型是text,需要分词得到关键字,根据分词后的关键字能检索到这条数据

    同时,这里设计了一个虚拟的属性:all,all这个属性从name 和 description 复制而来,目的是搜索某一个关键字,不管它是在name里还是在 description里都要能检索到这条数据,所以设置了一个name和description合并的属性all

    备注:因为之前创建了books索引,如果此处想用分词器重新创建索引,需要先把body清空执行一下delete

    重新get

     总结

     其中all是设计的字段,来自于name和description 的拷贝字段

     

    五 文档操作(数据操作)

    postman操作

     

     

    六 SpringBoot整合ES

    6.1 未使用分词器的整合

    1 导入高版本的依赖

    2 客户端

     

     2 客户端(改进)

     

     6.2 使用分词器整合

    和6.1的区别

     6.3 添加文档

     

     6.4 查询文档

    Query里的all就是前面设计的all = name + description

    hit就是得到的里面的一条数据

     getSourceAsString 就是 下面的这个_source数据

     

  • 相关阅读:
    RRC configured BWP
    软件测试必须要注意的地方
    创建阿里云的免费镜像仓库
    如何解决前端上线之后用户页面不刷新的问题
    js实现鼠标拖拽改变div大小的同时另一个div宽度也变化
    NODEJS 高级使用 http模块 express框架 路由 web服务器 中间件
    自己动手从零写桌面操作系统GrapeOS系列教程——16.封装打印字符串函数
    汇编 80x86 计算机组织
    八月集训day05——链表 + 双指针
    在linux服务器中使用rz上传文件乱码问题解决办法
  • 原文地址:https://blog.csdn.net/m0_45877477/article/details/125523765
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号