java操作ElasticSearch(包含增删改查及基础语法操作)

初始化客户端

跟操作数据库一样,写入地址、账号密码,获取一个客户端,有兴趣的可以看org.springframework.data.elasticsearch.client.ClusterNodesspring boot是怎么解析集群的

private TransportClient client;

private String[] nodes = new String[]{“127.0.0.1:9200”};

@Before

public void initClint() {

Settings settings = Settings.builder()

// es 集群的名称

.put(“cluster.name”, “elasticsearch”)

.put(“client.transport.sniff”, “true”)

//账号密码

.put(“xpack.security.user”, “elastic:123456”)

.build();

client = new PreBuiltXPackTransportClient(settings)

//添加集群节点

.addTransportAddresses(parseAddress());

}

创建索引

可以理解为创建一个mysql数据库表

@Test

public void createIndex() {

client.admin()

.indices()

.prepareCreate(“elastic”).get();

client.close();

}

设置mappings

mappings可以理解为mysql的表字段(json数据)

对应的json格式:

{

“properties”: {

“id”: {

“type”: “long”,

“store”: true

},

“name”: {

“type”: “text”,

“store”: true

},

“age”: {

“type”: “integer”,

“store”: true

}

}

}

对应的Java格式:

XContentBuilder builder = XContentFactory.jsonBuilder()

.startObject() // 相当于json的’{’

.startObject(“properties”)

.startObject(“id”)

.field(“type”, “long”) //字段类型

.field(“store”, true) //是否存储

.endObject() //相当于json的’}’

.startObject(“name”)

.field(“type”, “text”)

.field(“store”, true)

.field(“analyzer”, “ik_smart”) //采用ik_smart分词 “search_analyzer”: “ik_smart”

.endObject()

.startObject(“age”)

.field(“type”, “integer”)

.field(“store”, true)

.endObject()

.startObject(“desc”)

.field(“type”, “text”)

.field(“store”, true)

.field(“analyzer”, “ik_max_word”)

.endObject()

.startObject(“registerTime”)

.field(“type”, “date”)

.field(“store”, true)

.field(“format”, “yyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis”)

.endObject()

.endObject()

.endObject();

client.admin().indices()

.preparePutMapping(“elastic”)

.setType(“user”) //对应数据库的表名称

.setSource(builder)

.get();

client.close();

基础语法


1.1常用查询

1、查询全部:match_all

2、模糊匹配: match (类似sql 的 like)

3、全句匹配: match_phrase (类似sql 的 = )

4、多字段匹配:muti_match (多属性查询)

5、语法查询:query_string (直接写需要配置的 关键字 )

6、字段查询 : term (针对某个属性的查询,这里注意 term 不会进行分词,比如 在 es 中 存了 “火锅” 会被分成 “火/锅” 当你用 term 去查询 “火时能查到”,但是查询 “火锅” 时,就什么都没有,而 match 就会将词语分成 “火/锅”去查)

7、范围查询:range ()

1.2 增删改查

1.2.1.插入操作

Java插入操作代码:

示例一:

String index = “test1”;

String type = “_doc”;

// 唯一编号

String id = “1”;

IndexRequest request = new IndexRequest(index, type, id);

String jsonString = “{” + ““uid”:“1234”,”+ ““phone”:“12345678909”,”+ ““msgcode”:“1”,” + ““sendtime”:“2019-03-14 01:57:04”,”

  • ““message”:“xuwujing study Elasticsearch”” + “}”;

request.source(jsonString, XContentType.JSON);

IndexResponse indexResponse = client.index(request, RequestOptions.DEFAULT);

示例二:

String index = “test1”;

String type = “_doc”;

// 唯一编号

String id = “1”;

IndexRequest request = new IndexRequest(index, type, id);

Map<String, Object> jsonMap = new HashMap<>();

jsonMap.put(“uid”, 1234);

jsonMap.put(“phone”, 12345678909L);

jsonMap.put(“msgcode”, 1);

jsonMap.put(“sendtime”, “2019-03-14 01:57:04”);

jsonMap.put(“message”, “xuwujing study Elasticsearch”);

request.source(jsonMap);

IndexResponse indexResponse = client.index(request, RequestOptions.DEFAULT);

示例三:

String index = “test1”;

String type = “_doc”;

// 唯一编号

String id = “1”;

IndexRequest request = new IndexRequest(index, type, id);

XContentBuilder builder = XContentFactory.jsonBuilder();

builder.startObject();

{

builder.field(“uid”, 1234);

builder.field(“phone”, 12345678909L);

builder.field(“msgcode”, 1);

builder.timeField(“sendtime”, “2019-03-14 01:57:04”);

builder.field(“message”, “xuwujing study Elasticsearch”);

}

builder.endObject();

request.source(builder);

IndexResponse indexResponse = client.index(request, RequestOptions.DEFAULT);

1> 使用自定义的id

使用put方式,并自己提供id

类似于下面的格式

PUT /{index}/{type}/{id}

{

“field”: “value”,

}

请求

PUT /website/blog/123

{

“title”: “My first blog entry”,

“text”: “Just trying this out…”,

“date”: “2014/01/01”

}

响应

{

“_index”: “website”,

“_type”: “blog”,

“_id”: “123”,

“_version”: 1,

“created”: true

}

自动生成的 ID 是 URL-safe、 基于 Base64 编码且长度为20个字符的 GUID 字符串。 这些 GUID 字符串由可修改的 FlakeID 模式生成,这种模式允许多个节点并行生成唯一 ID ,且互相之间的冲突概率几乎为零。

1.2.2.更改操作

Java示例代码:

private static void update() throws IOException {

String type = “_doc”;

String index = “test1”;

// 唯一编号

String id = “1”;

UpdateRequest upateRequest = new UpdateRequest();

upateRequest.id(id);

upateRequest.index(index);

upateRequest.type(type);

// 依旧可以使用Map这种集合作为更新条件

Map<String, Object> jsonMap = new HashMap<>();

jsonMap.put(“uid”, 12345);

jsonMap.put(“phone”, 123456789019L);

jsonMap.put(“msgcode”, 2);

jsonMap.put(“sendtime”, “2019-03-14 01:57:04”);

jsonMap.put(“message”, “xuwujing study Elasticsearch”);

upateRequest.doc(jsonMap);

// upsert 方法表示如果数据不存在,那么就新增一条

upateRequest.docAsUpsert(true);

client.update(upateRequest, RequestOptions.DEFAULT);

System.out.println(“更新成功!”);

}

控制台输入

PUT /website/blog/123

{

“title”: “My first blog entry”,

“text”: “Just trying this out…”,

“date”: “2014/01/01”

}

在响应体中,我们能看到 Elasticsearch 已经增加了 _version 字段值,created 标志设置成 false ,是因为相同的索引、类型和 ID 的文档已经存在。

{

“_index”: “website”,

“_type”: “blog”,

“_id”: “123”,

“_version”: 2,

“created”: false

}

1.2.3.删除操作

Java示例代码:

示例一(正常根据ID删除):

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后

小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!

程序员代码面试指南 IT名企算法与数据结构题目最优解

这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!

image.png

《TCP-IP协议组(第4版)》

本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。

本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。

image.png

Java开发手册(嵩山版)

这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**

image.png

MySQL 8从入门到精通

本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。

image.png

Spring5高级编程(第5版)

本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。

本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。

image.png

JAVA核心知识点+1000道 互联网Java工程师面试题

image.png

image.png

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

image.png

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

经验,包括远程处理、事务、Web 和表示层,等等。

[外链图片转存中…(img-uE3mbEFD-1712425163510)]

JAVA核心知识点+1000道 互联网Java工程师面试题

[外链图片转存中…(img-svBqQXzj-1712425163511)]

[外链图片转存中…(img-2vKufpBt-1712425163511)]

企业IT架构转型之道 阿里巴巴中台战略思想与架构实战

本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。

[外链图片转存中…(img-BmkeU1JM-1712425163512)]

一个人可以走的很快,但一群人才能走的更远。如果你从事以下工作或对以下感兴趣,欢迎戳这里加入程序员的圈子,让我们一起学习成长!

AI人工智能、Android移动开发、AIGC大模型、C C#、Go语言、Java、Linux运维、云计算、MySQL、PMP、网络安全、Python爬虫、UE5、UI设计、Unity3D、Web前端开发、产品经理、车载开发、大数据、鸿蒙、计算机网络、嵌入式物联网、软件测试、数据结构与算法、音视频开发、Flutter、IOS开发、PHP开发、.NET、安卓逆向、云计算

  • 7
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值