过去十年,AI算法的落地集中在人脸识别、车牌识别等社会治理领域,安防、交通是AI技术最快实现产业化、市场化的行业应用。但其实,AI在更广阔的领域,比如工业、教育、医疗、农业等领域,还有很大的市场空间正待开发,未来各行各业将涌现出大量的AI算法生产需求。然而,AI算法开发生产过程周期长、专业门槛高、成本高的问题,一直是制约AI成功落地的一大因素。一个AI算法从提出规划想法,到模型最终上线,需要10-15人的开发团队,整个开发周期长达数月,其效率和成本都无法应对未来大规模AI场景落地的需要。目前,各行业的软件开发商或系统集成商,在实际项目中都需要定制化开发AI算法。共达地高级市场总监李苏南认为,作...... Last article READ

ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客

写在前面

继续记录自己的SpringBoot学习之旅,这次是SpringBoot应用相关知识学习记录。若看不懂则建议先看前几篇博客,详细代码可在我的Gitee仓库SpringBoot克隆下载学习使用!

3.4.3.4 ElasticSearch(ES)

3.4.3.4.1 介绍
  • 是一个分布式全文搜索引擎
  • 主要应用于需要搜索的功能里,比如商城
  • 关键是倒排索引,根据关键词找到对应索引,再根据索引找到具体的数据
3.4.3.4.2 安装
  • 点击下载,选择对应版本即可,这里是7.16.2
  • 下载解压后点击elasticsearch.bat即可启动服务,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
  • 在浏览器输入地址localhost:9200,出现如图即可成功ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
3.4.3.4.3 操作
  • 使用软件:postman或者Apifox
  • 使用插件:IK分词器,点击下载解压后放在之前下好的ES中的插件目录plugins中
  • 创建索引。添加put请求并指定分词规则,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
    ,分词规则如下:
{     "mappings": {         "properties": {             "id": {                 "type": "keyword"             },             "name": {                 "type": "text",                 "analyzer": "ik_max_word",                 "copy_to": "all"             },             "password": {                 "type": "text",                 "analyzer": "ik_max_word",                 "copy_to": "all"             },             "age": {                 "type": "keyword"             },             "all": {                 "type":"text",                 "analyzer":"ik_max_word"             }         }     } } 
  • 删除索引,同上,使用DELETE请求
  • 查询索引,同上,使用GET请求,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
  • 添加文档(数据),同上,使用POST请求,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
  • 其中有3种方式:
    • xxx/_ doc:id为默认
    • xxx/ _ doc/2:指定id为2_
    • xxx/_ create/3:指定id为3
  • 查询文档全部数据,使用GET,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
    ,查询单个则是xxx/ _ doc/id格式
  • 删除文档数据,同上,用DELETE请求,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
  • 修改文档数据类似添加,主要有两种:
    • 全量修改,直接覆盖掉原有的,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
    • 部分修改,仅仅修改需要修改部分,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
3.4.3.4.4 SpringBoot整合
  • 新建项目
  • 添加ES高版本坐标,如图ElasticSearch是什么?ElasticSearch在SpringBoot中怎么用?SpringBoot整合ElasticSearch_花花的小脑瓜的博客
  • 无需配置
  • 客户端操作
    • 创建索引
private RestHighLevelClient client; @Test void createIndex() throws IOException { HttpHost host = HttpHost.create("http://localhost:9200");; RestClientBuilder builder = RestClient.builder(host);           client = new RestHighLevelClient(builder); //        客户端操作   CreateIndexRequest request = new CreateIndexRequest("users");           client.indices().create(request, RequestOptions.DEFAULT); //        关闭客户端           client.close(); } 
  • 添加文档
//    创建文档   @Test public void addESDoc() throws IOException { IndexRequest indexRequest = new IndexRequest("users").id("1"); String json = "{n" + "    "name": "大家",n" + "    "password": "早上好大家",n" + "    "age": 23n" + "}";           indexRequest.source(json,XContentType.JSON);           client.index(indexRequest,RequestOptions.DEFAULT); } 

其它具体详见Gitee上的项目

🏆个人主页:企鹅不叫的博客 ​ 🌈专栏 C语言初阶和进阶C项目Leetcode刷题初阶数据结构与算法C++初阶和进阶《深入理解计算机操作系统》《高质量C/C++编程》Linux ⭐️ 博主码云gitee链接:代码仓库地址 ⚡若有帮助可以【关注+点赞+收藏】,大家一起进步! 💙系列文章💙 【Linux】第一章环境搭建和配置 【Linux】第二章常见指令和权限理解 【Linux】第三章Linux环境基础开发工具使用(yum+......Next article READ