一、ES基本概念

1. 节点:Elastic是一个分布式数据库,每个数据库实例是一个节点Node,一台服务器上可以有多个Node,可以多台服务器协同工作

2. 集群:一组节点Node构成一个集群Cluster

3. 文档:存储数据的基本单元称为文档Document,使用json表示

4. 索引:索引Index是一类文档的集合,ES会索引所有字段,经过处理后写入一个反向索引

5. 类型:一个索引的逻辑分区叫类型Type

6. 分词器:把text类型的数据进行分词,分词后按照分词建立索引,可以按照分词进行查询;默认分词器为ik,可以设置为中文分词器ik_max_word

二、跟普通数据库mysql在数据结构上的区别

mysql:库->表->行->字段

ES:索引->类型->文档->字段

三、数据类型

1.ES在5.*版本之后,把string字段设置为了过时字段,引入text,keyword字段

2.text会自动分词,keyword不分词,因为全部字段分词,会浪费空间

3.如果不在mapping中定义字段类型,java的String类型会自动映射成text & keyword两种

4.如果ES中已经有数据,不支持修改字段类型

a.可以删除原来索引,重新建立

b.新建一个索引,把老数据迁移到新索引上面

c.如果数据比较多或者比较重要,可以新增一个字段

三、增删改查API

1.新增或者更新,/index/type/id已存在就会更新

put /index/type/id

{

"field1":"value1",

"field2":"value2"

}

2.删除

delete /index/type/id

3.查询

term:精确匹配一个字段

match:模糊查询或者分词查询一个字段

wildcard:使用通配符进行查询

四、Java操作ES的方式,建议使用rest方式

1.TransportClient,通过TCP方式访问ES,只支持java,以后可能废除,不建议使用

a.引入依赖

        <dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>transport</artifactId>
<version>6.7.1</version>
</dependency>

b.创建client

// 设置集群的名字
Settings settings = Settings.builder().put("cluster.name", clusterName)
.put("client.transport.sniff", false)
.put("request.headers.Authorization", basicAuthHeaderValue(userName, password))
.build();
// 创建集群client并添加集群节点地址
PreBuiltTransportClient c = new PreBuiltTransportClient(settings);
c.addTransportAddress(new TransportAddress(InetAddress.getByName(host), Integer.parseInt(port)));

c.使用client增删改查

2.JestClient

a.引入依赖

        <dependency>
<groupId>io.searchbox</groupId>
<artifactId>jest</artifactId>
</dependency>

b.创建client

https://blog.csdn.net/weixin_42685328/article/details/111408562

c.使用client增删改查

3.RestClient,通过HTTP方式访问ES,没有语言限制,和transport不能同时使用

low-level-client

https://blog.csdn.net/weixin_33831673/article/details/91447794

4.RestHighLevelClient,推荐使用

a.引入jar包

      <dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>elasticsearch-rest-high-level-client</artifactId>
<version>6.7.1</version>
</dependency>

b.创建client

@Configuration
public class EsConfig {
private static final int HTTP_PORT = 9200;
private static final String IP = "aaa";
private static final String SecurityUser = "aaa";
private static final String SecurityPassword = "aaa"; private static CredentialsProvider init() {
CredentialsProvider credentialsProvider = new BasicCredentialsProvider();
credentialsProvider.setCredentials(AuthScope.ANY,
new UsernamePasswordCredentials(SecurityUser, SecurityPassword));
return credentialsProvider;
} @Bean
public RestClientBuilder restClientBuilder() {
//配置权限验证
RestClientBuilder restClientBuilder = RestClient.builder( new HttpHost(IP, HTTP_PORT, "http"))
.setHttpClientConfigCallback(httpClientBuilder ->
httpClientBuilder.setDefaultCredentialsProvider(init()));
return restClientBuilder;
} @Bean(name = "highLevelClient")
public RestHighLevelClient highLevelClient(@Autowired RestClientBuilder restClientBuilder) {
return new RestHighLevelClient(restClientBuilder);
} }

c.写数据

IndexRequest request = new IndexRequest();
request.index(index).type(type).source(JSON.toJSONString(object), XContentType.JSON);
bulkRequest.add(request);
// 保存数据到ES
BulkResponse bulkResponse = highLevelClient.bulk(bulkRequest, RequestOptions.DEFAULT);

d.读数据 BoolQueryBuilder的should/must,对应mysql的or/and

SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
// 分页参数
searchSourceBuilder.from(1);
searchSourceBuilder.size(10);
searchSourceBuilder.sort("_id", SortOrder.DESC); BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery()
// 精确匹配
.must(QueryBuilders.termQuery("field1","value1")
// 关键字模糊+分词匹配
.must(QueryBuilders.multiMatchQuery("keyword","field1","field2","field3","field4","field5")); searchSourceBuilder.query(boolQueryBuilder); SearchRequest searchRequest = new SearchRequest();
searchRequest.source(searchSourceBuilder);

SearchResponse searchResponse = highLevelClient.search(searchRequest, RequestOptions.DEFAULT);

if (Objects.nonNull(searchResponse)) {
total = searchResponse.getHits().totalHits;

SearchHits searchHits = searchResponse.getHits();
for (int i = 0; i < searchHits.getHits().length; i++) {
String str = searchHits.getHits()[i].getSourceAsString();
    }
}

e.删除数据

        DeleteRequest deleteRequest = new DeleteRequest();
deleteRequest.index(index).type(type).id(id); try {
highLevelClient.delete(deleteRequest, RequestOptions.DEFAULT);
} catch (Exception ex) {
log.error("删除ES中的数据异常", ex);
}

5.Spring-data-elasticsearch

https://blog.csdn.net/qq_44657532/article/details/123622136

6.bboss框架

https://esdoc.bbossgroups.com/#/quickstart

参考:

https://www.cnblogs.com/javallh/p/13790486.html

https://www.cnblogs.com/dreamroute/p/8484457.html

https://www.cnblogs.com/zwt1990/p/7737747.html

http://www.ruanyifeng.com/blog/2017/08/elasticsearch.html

https://www.cnblogs.com/yixinjishu/p/11057933.html

https://blog.csdn.net/qq_41937849/article/details/87368585

Java操作ES的更多相关文章

  1. Elasticsearch笔记五之java操作es

    Java操作es集群步骤1:配置集群对象信息:2:创建客户端:3:查看集群信息 1:集群名称 默认集群名为elasticsearch,如果集群名称和指定的不一致则在使用节点资源时会报错. 2:嗅探功能 ...

  2. 2 - 基于ELK的ElasticSearch 7.8.x技术整理 - java操作篇 - 更新完毕

    3.java操作ES篇 3.1.摸索java链接ES的流程 自行创建一个maven项目 3.1.1.依赖管理 点击查看代码 <properties> <ES-version>7 ...

  3. java操作ElasticSearch(es)进行增删查改操作

    有时间是要了解一下ES这个东西的~ ---------------------------------------------------------------------------------- ...

  4. Es学习第十一课,使用java操作elasticsearch

    前面十节课我们已经把ES的基本概念和使用讲的差不多了,现在我们就用基于java来实际开发一个操作ES的小项目,带大家来一起练练手. 1.我们用IDEA创建一个maven项目 项目结构如上图所示,然后我 ...

  5. 使用java操作elasticsearch之与es简历连接

    Elasticsearch 的 Java 客户端非常强大:它可以建立一个嵌入式实例并在必要时运行管理任务. 运行一个 Java 应用程序和 Elasticsearch 时,有两种操作模式可供使用.该应 ...

  6. java操作elasticsearch实现组合桶聚合

    1.terms分组查询 //分组聚合 @Test public void test40() throws UnknownHostException{ //1.指定es集群 cluster.name 是 ...

  7. java操作elasticsearch实现query String

    1.CommonTersQuery: 指定字段进行模糊查询 //commonTermsQuery @Test public void test35() throws UnknownHostExcept ...

  8. java操作elasticsearch实现聚合查询

    1.max 最大值 //max 求最大值 @Test public void test30() throws UnknownHostException{ //1.指定es集群 cluster.name ...

  9. java操作elasticsearch实现前缀查询、wildcard、fuzzy模糊查询、ids查询

    1.前缀查询(prefix) //prefix前缀查询 @Test public void test15() throws UnknownHostException { //1.指定es集群 clus ...

  10. java操作elasticsearch实现条件查询(match、multiMatch、term、terms、reange)

    1.条件match query查询 //条件查询match query @Test public void test10() throws UnknownHostException { //1.指定e ...

随机推荐

  1. Postgres的count统计误区

    数据库统计数据量时常常用的是count(1)或者count(*),这两者区别不大,在postgres里面统计数据总量时,要注意count(column_name)与count(*)的区别,有些场景下会 ...

  2. 动手写了个简单版的ChatGPT的Java版客户端

    最近ChatGpt大火,我在年前申请过账号忘了下确实强大. 作为Java程序猿社畜就尝试写了个Java版本的简易版客户端. 源码地址:https://github.com/Grt1228/chatgp ...

  3. Prometheus监控操作

    一.架构说明 ➢ Prometheus Server:Prometheus 生态最重要的组件,主要用于抓取和存储时间序列数据, 同时提供数据的查询和告警策略的配置管理: ➢  Alertmanager ...

  4. element-ui的collapse中嵌套table表格 的 高度跳跃 问题

    <script src="//unpkg.com/vue@2.6.10/dist/vue.js"></script><script src=" ...

  5. SVG 从入门到后悔,怎么不早点学起来(图解版)

    点赞 + 关注 + 收藏 = 学会了 作为一只前端,只懂 Vue.React 感觉已经和大家拉不开距离了. 可视化.机器学习等领域 JS 都有涉及到,而可视化方面已经被很多领域用到,比如大屏项目. 可 ...

  6. Vue项目中怎样把参数(对象)转成formdata传给后端? 封装函数 亲测有效

    普通传参格式如下: 想要的formData参数格式如下: 首先封装参数(对象)转换为formData格式 getFormData(object) { const formData = new Form ...

  7. redis底层数据结构之字典(dict)

    字典(dict) 字典又称为符号表或者关联数组.或映射(map),是一种用于保存键值对(key-value)的抽象数据结构 字典中的每个key都是唯一的,通过key对值来进行查找或修改,时间复杂度为 ...

  8. db2查看表结构、表索引

    1.1 db2查看表结构 SELECT * FROM "SYSIBM".syscolumns WHERE TBNAME = 'table_name ' AND TBCREATOR ...

  9. apollo源码同时兼容mysql、postgresql、oracle解决思路

    本文摘录 apollo源码采用的是jpa规范 Hibernate 进行持久化的ORM框架 解决思路: 思路一:使用jpa配置文件persistence.xml文件,根据使用的数据库动态加载实体类与数据 ...

  10. zzul1073_Java

    import java.util.Scanner;/** * 限制解是正数,且脚数为偶数即可 */public class zzul1073 { public static void main(Str ...