ElasticSearch入门

一、倒排索引

将文档进行分词,形成词条和数据id的对应关系即为反向索引。

ElasticSearch入门_第1张图片

 二、ElasticSearch和Kibana安装

安装:略。

Kibana是一个针对Elasticsearch的开源分析及可视化平台,用来搜索、查看交互存储在Elasticsearch索引中的数据。使用Kibana,可以通过各种图表进行高级数据分析及展示。

三、ElasticSearch核心概念

索引(index)

ElasticSearch存储数据的地方,可以理解成关系型数据库中的数据库概念。

映射(mapping)

mapping定义了每个字段的类型、字段所使用的分词器等。相当于关系型数据库中的表结构。

文档(document)

Elasticsearch中的最小数据单元,常以json格式显示。一个document相当于关系型数据库中的一行数据。

四、操作索引

1、添加索引

put请求:http://ip:端口/索引名称

2、查询

get请求:

http://ip:端口/索引名称  # 查询单个索引信息
http://ip:端口/索引名称1,索引名称2...  # 查询多个索引信息
http://ip:端口/_all  # 查询所有索引信息

3、删除索引

delete请求:http://ip:端口/索引名称

4、关闭、打开索引

post请求:

http://ip:端口/索引名称/_close  
http://ip:端口/索引名称/_open 

五、操作映射

一、数据类型

1、简单数据类型

(1)字符串

text:会分词,不支持聚合(sum)

keyword:不会分词,将全部内容作为一个词条,支持聚合(sum)

(2)数值

(3)布尔:boolean

(4)二进制:binary

(5)范围类型

integer_range, float_range, long_range, double_range, date_range 

(6)日期:date

二、复杂数据类型

1、数组:[]

2、对象:{}

三、操作映射

(1)创建索引并添加映射
 PUT /person1
{
  "mappings": {
    "properties": {
      "name": {
        "type": "text"
      },
      "age": {
        "type": "integer"
      }
    }
  }
}

GET person1/_mapping

 (2)添加字段

PUT /person1/_mapping
{
  "properties": {
      "name": {
        "type": "text"
      },
      "age": {
        "type": "integer"
      }
    }
}

六、操作文档

1、添加文档,指定id

POST /person1/_doc/2
{
  "name":"张三",
  "age":18,
  "address":"北京"
}

2、添加文档,不指定id,会自动生成随机id

POST /person1/_doc/
{
  "name":"张三",
  "age":18,
  "address":"北京"
}

3、删除指定id文档

DELETE /person1/_doc/1

4、查询文档

#根据id查询文档      GET /person1/_doc/1

#查询所有文档         GET /person1/_search

七、查询文档

1、IK分词器

IK分词器有两种分词模式:ik_max_word(细粒度拆分)和 ik_smart模式(粗粒度拆分)。

2、查询文档

(1)词条查询:term

词条查询不会分析查询条件,只有当词条和查询字符串完全匹配时才匹配搜索

GET /person2/_search
{
  "query": {
    "term": {
      "address": {
        "value": "北京"
      }
    }
  }
}

(2)全文查询:match

全文查询会分析查询条件,先将查询条件进行分词,然后查询,求并集

GET /person2/_search
{
  "query": {
    "match": {
      "address":"北京昌平"
    }
  }
}

八、ElasticSearch Java操作

一、Springboot整合ES


        
            org.elasticsearch.client
            elasticsearch-rest-high-level-client
            7.4.0
        
        
            org.elasticsearch.client
            elasticsearch-rest-client
            7.4.0
        
        
            org.elasticsearch
            elasticsearch
            7.4.0
        

二、添加索引,并添加映射;查询索引;删除索引

//添加索引
//1.使用client获取操作索引对象
IndicesClient indices = client.indices();
//2.具体操作获取返回值
//2.具体操作,获取返回值
CreateIndexRequest createIndexRequest = new CreateIndexRequest("itcast");
//2.1 设置mappings
String mapping = "{\n" +
                "      \"properties\" : {\n" +
                "        \"address\" : {\n" +
                "          \"type\" : \"text\",\n" +
                "          \"analyzer\" : \"ik_max_word\"\n" +
                "        },\n" +
                "        \"age\" : {\n" +
                "          \"type\" : \"long\"\n" +
                "        },\n" +
                "        \"name\" : {\n" +
                "          \"type\" : \"keyword\"\n" +
                "        }\n" +
                "      }\n" +
                "    }";
createIndexRequest.mapping(mapping,XContentType.JSON);

CreateIndexResponse createIndexResponse = indices.create(createIndexRequest,         
    RequestOptions.DEFAULT);
//3.根据返回值判断结果
System.out.println(createIndexResponse.isAcknowledged());

//查询索引
GetIndexRequest getRequest=new GetIndexRequest("itcast");
GetIndexResponse response = indices.get(getRequest, RequestOptions.DEFAULT);
Map mappings = response.getMappings();
for (String key : mappings.keySet()) {
    System.out.println(key+"==="+mappings.get(key).getSourceAsMap());
}

//删除索引
DeleteIndexRequest deleteRequest=new DeleteIndexRequest("itcast");
        AcknowledgedResponse delete = indices.delete(deleteRequest, RequestOptions.DEFAULT);
        System.out.println(delete.isAcknowledged());

//索引是否存在
boolean exists = indices.exists(getRequest, RequestOptions.DEFAULT);

 三、文档操作

//添加文档
Person person=new Person();
person.setId("2");
person.setName("李四");
person.setAge(20);
person.setAddress("北京三环");
String data = JSON.toJSONString(person);
IndexRequest request=new 
           IndexRequest("itcast").id(person.getId()).source(data,XContentType.JSON);
IndexResponse response = client.index(request, RequestOptions.DEFAULT);
System.out.println(response.getId());

//修改文档
Person person=new Person();
person.setId("2");
person.setName("李四");
person.setAge(20);
person.setAddress("北京三环车王");

String data = JSON.toJSONString(person);

IndexRequest request=new 
           IndexRequest("itcast").id(person.getId()).source(data,XContentType.JSON);
IndexResponse response = client.index(request, RequestOptions.DEFAULT);
System.out.println(response.getId());

//查询文档
//设置查询的索引、文档
GetRequest indexRequest=new GetRequest("itcast","2");
GetResponse response = client.get(indexRequest, RequestOptions.DEFAULT);
System.out.println(response.getSourceAsString());

//删除文档
//设置要删除的索引、文档
DeleteRequest deleteRequest=new DeleteRequest("itcast","1");
DeleteResponse response = client.delete(deleteRequest, RequestOptions.DEFAULT);
System.out.println(response.getId());

你可能感兴趣的:(ElasticSearch,elasticsearch,搜索引擎,大数据)