目录
?一、Rest风格说明
1.基本Rest命令说明
2.数据类型
二、关于索引的基本操作
1.新增
2.查看信息
3._doc表示默认类型
4.通过_cat获取详细信息
5.修改
6.删除
三、关于文档的基本操作
1.基本的增删改查
?2.根据ID查询
3.根据内容查询
4.查询结果只显示指定字段
5.根据字段排序
6.分页查询
7.布尔值查询
(1)and
(2)or
?(3)不等于(!=)
8.filter过滤
9.匹配多个内容查询
10.精确查询
(1)关于分词
(2)text和keyword
?(3)精确查询
11.多个值精确查询
12.高亮
四、SpringBoot集成ES
1.官网文档地址
?2.新建项目
3.自定义es的版本,配置config
(1)配置版本
(2)配置config
4.关于索引的API操作
5.关于文档的API操作
五、打赏请求
?一、Rest风格说明
Rest是一种软件架构风格,而不是标准,只是提供了一组设计原则和约束条件。他主要用于客户端和服务端交互的软件。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。
1.基本Rest命令说明
method | url地址 | 描述 | PUT | localhost:9200/索引名称/类型名称/文档ID | 创建文档(指定文档ID) | POST | localhost:9200/索引名称/类型名称 | 创建文档(随机文档ID) | POST | localhost:9200/索引名称/类型名称/文档ID/_update | 修改文档 | DELETE???????? | localhost:9200/索引名称/类型名称/文档ID | 删除文档 | GET | localhost:9200/索引名称/类型名称/文档ID | 通过文档ID查询文档 | POST | localhost:9200/索引名称/类型名称/_search???????? | 查询所有数据 |
实例:
data:image/s3,"s3://crabby-images/fa7f7/fa7f78b3f19bbaae6333fddce56a225e38b3511d" alt=""
2.数据类型
- 字符串类型:text,keyword
- 数值类型:long,integer,short,byte,double,float,half float,scaled float
- 日期类型:date
- 布尔值类型:boolean
- 二进制类型:binary
二、关于索引的基本操作
1.新增
data:image/s3,"s3://crabby-images/730f0/730f030e772e3cd74ea9cbf63f21e5369b31d0d4" alt=""
2.查看信息
GET
data:image/s3,"s3://crabby-images/2e09e/2e09e2c6d8f6eadbfa1300cfe7d76718f6a620c6" alt=""
3._doc表示默认类型
type后面逐渐被弃用,我们用_doc来表示默认类型。
PUT /aa/_doc/bb
data:image/s3,"s3://crabby-images/84259/84259901839cd1bc9cbb907e1405cdad613bc87d" alt=""
4.通过_cat获取详细信息
GET _cat/
data:image/s3,"s3://crabby-images/e77e4/e77e45dac611d3b2f5bcf4bcb478025cf17ab858" alt=""
5.修改
*1)方法一
?在要修改的url后面添加_update,然后修改的内容加一层"doc",然后将自己要修改的字段放进去,就可修改指定字段,其他字段保持不变。
data:image/s3,"s3://crabby-images/98ab4/98ab45284a6419380593595b8ea8b61dbc2c5317" alt=""
?data:image/s3,"s3://crabby-images/707c6/707c67aca4a5593fd820d62bf64fc840926d8523" alt=""
*2)方法二?
准确的说,这个不是修改,是覆盖,不推荐
data:image/s3,"s3://crabby-images/caff0/caff0cb95cce8d33256105f3f1bb2ae5f5fc6fec" alt=""
?data:image/s3,"s3://crabby-images/33f0d/33f0d433109ae7926723e41b3a2fe7b21923a78b" alt=""
6.删除
data:image/s3,"s3://crabby-images/ce3a4/ce3a4cf924568c7b6300e79b4cd21445f0f32caa" alt=""
三、关于文档的基本操作
注意,这里的每一个操作都对应java里的一个API。
1.基本的增删改查
首先文档的基本增删改查和索引是一样的,包括PUT是新增,GET是查看,更新的两种方法也是完全一样。
data:image/s3,"s3://crabby-images/b2780/b27805d7e2c1110c6c4973a29b8f00b794324a89" alt=""
?2.根据ID查询
注意:所有的搜索都必须GET方法
data:image/s3,"s3://crabby-images/062e8/062e81b5d7bcc3a43439e491ccacf4955321c8a5" alt=""
3.根据内容查询
es内部会拆分你的内容,汉字会拆分成一个个的字,只要匹配上就给你查出来。
以下两种方法,写法不同,效果是一样的
(1)方法一
GET /xupeng/user/_search?q=name:鹏哥
如图,因为包含鹏字,所以会被查出来,但是分数很低?
q:
data:image/s3,"s3://crabby-images/937a6/937a6524c6f388f751fea3d8899e082d3668b9c8" alt=""
(2)方法二
GET /xupeng/user/_search
{
"query": {
"match": {
"name": "鹏哥"
}
}
}
4.查询结果只显示指定字段
显示指定字段:
GET /xupeng/user/_search
{
"query": {
"match": {
"name": "鹏哥"
}
},
"_source": ["name","tags"]
}
data:image/s3,"s3://crabby-images/d24e8/d24e856864af924d35ae474c4839daaa9a59673a" alt=""
5.根据字段排序
排序:
GET /xupeng/user/_search
{
"query": {
"match": {
"name": "鹏"
}
},
"_source": ["name","tags","age"],
"sort": [
{
"age": {
"order": "asc"
}
}
]
}
data:image/s3,"s3://crabby-images/4f1f1/4f1f196735b218e05be26c83fd50c27211a02298" alt=""
6.分页查询
分页:
GET /xupeng/user/_search
{
"query": {
"match": {
"name": "鹏"
}
},
"_source": ["name","tags","age"],
"sort": [
{
"age": {
"order": "asc"
}
}
],
"from": 0,
"size": 2
}
data:image/s3,"s3://crabby-images/949d8/949d886c2a45866beccb1cb601bc8108d3413acb" alt=""
?注:下标从0开始计算?
7.布尔值查询
其实就是对应的多个条件查询。and和or的区别就是bool下面一个是must,一个是should
(1)and
这里稍微解释一下,字符串因为会被拆解,所以只要包含鹏这个字的都会匹配。但是age因为是数字,必须要一样才能匹配:
GET /xupeng/user/_search
{
"query": {
"bool": {
"must": [
{
"match": {
"name":"鹏"
}
},
{
"match": {
"age":44
}
}
]
}
}
}
data:image/s3,"s3://crabby-images/8e022/8e022692eac9fb673058be1ee61624a7a5a77334" alt=""
(2)or
GET /xupeng/user/_search
{
"query": {
"bool": {
"should": [
{
"match": {
"name":"鹏"
}
},
{
"match": {
"age":44
}
}
]
}
}
}
data:image/s3,"s3://crabby-images/aef45/aef452c04450a387331dbf9937290dc12fced746" alt=""
?(3)不等于(!=)
此处的must_not可以理解为!=
GET /xupeng/user/_search
{
"query": {
"bool": {
"must_not": [
{
"match": {
"name":"鹏"
}
},
{
"match": {
"age":44
}
}
]
}
}
}
data:image/s3,"s3://crabby-images/6f0d7/6f0d72e41b958c9726e10afe56e77eadfabf0efa" alt=""
8.filter过滤
对应了sql里的>=和<=
GET /xupeng/user/_search
{
"query": {
"bool": {
"must": [
{
"match": {
"name":"鹏"
}
}
],
"filter": {
"range": {
"age": {
"gte": 40,
"lte": 99
}
}
}
}
}
}
?data:image/s3,"s3://crabby-images/5b78c/5b78c1c5d2ca852e33288fd86b956ac2e1d45e16" alt=""
9.匹配多个内容查询
GET /xupeng/user/_search
{
"query": {
"match": {
"tags": "西游 中药"
}
}
}
data:image/s3,"s3://crabby-images/237f4/237f471c865e81ce6ba49fb8210986715c5d42fb" alt=""
10.精确查询
trem查询是直接通过倒排索引指定的词条进行精确查询。
(1)关于分词
- term:直接根据倒排索引查询(效率高,类似于sql里的=)
- match:使用分词器解析(先分析文档,在通过分析的文档进行查询)
(2)text和keyword
text会被分词器解析,keyword不会被分词器解析
data:image/s3,"s3://crabby-images/2a31e/2a31ecf15e1d137d2b13473b70c8087d0da4d3a3" alt=""
?data:image/s3,"s3://crabby-images/c8395/c839507d07b71806be6c82ee3143c9a12fd5baab" alt=""
?(3)精确查询
GET testdb/_search
{
"query": {
"term": {
"name": "鹏"
}
}
}
GET testdb/_search
{
"query": {
"term": {
"desc": "徐鹏写java desc"
}
}
}
data:image/s3,"s3://crabby-images/2d8c5/2d8c555152394140e340b3c8c8de45a6b88bf1fa" alt=""
?data:image/s3,"s3://crabby-images/c6608/c66084d3337a0cc83ba72d7fc06b761e990dd92d" alt=""
11.多个值精确查询
这句话的作用表示: t1 = 22 or t1 = 33
?完成多个值得查询:data:image/s3,"s3://crabby-images/853c9/853c9655aa51acd6f012d48bd49d573e6d74966b" alt=""
12.高亮
搜索的结果高亮显示:
GET /xupeng/user/_search
{
"query": {
"match": {
"name": "徐鹏"
}
},
"highlight": {
"pre_tags": "<p class='key' style='color:red'>",
"post_tags": "</p>",
"fields": {
"name":{}
}
}
}
data:image/s3,"s3://crabby-images/a158c/a158cdf33797d12f1e056ba4675574f67804155d" alt=""
四、SpringBoot集成ES
1.官网文档地址
https://www.elastic.co/guide/en/elasticsearch/client/index.html
data:image/s3,"s3://crabby-images/c156a/c156ab901c13380d78b883470bb74c09476c9e75" alt=""
?2.新建项目
data:image/s3,"s3://crabby-images/4350e/4350ea4952b16a0207db52fd515f4ee4a20da586" alt=""
?data:image/s3,"s3://crabby-images/a0dd0/a0dd018caf6a614ebba45d4ee7caa1c91dcc40fb" alt=""
3.自定义es的版本,配置config
(1)配置版本
<dependency>都是springboot帮我们设置好的,我们只需要指定es的版本即可。
这一步很重要,一定要设置!?
data:image/s3,"s3://crabby-images/35a2c/35a2c836c027dfbac0e64f1ee32045c18a4a86d0" alt=""
(2)配置config
data:image/s3,"s3://crabby-images/8588c/8588cf2c3469aff01c1f6b12fda5d1f224d4437c" alt=""
ElasticSearchConfig:
package com.xupeng.esapi.config;
import org.apache.http.HttpHost;
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* [一句话描述该类的功能]
*
* @author : [xupeng]
* @version : [v1.0]
* @createTime : [2021/7/14 18:44]
*/
@Configuration
public class ElasticSearchConfig {
@Bean
public RestHighLevelClient restHighLevelClient(){
RestHighLevelClient client = new RestHighLevelClient(
RestClient.builder(
new HttpHost("localhost",9200,"http")));
return client;
}
}
4.关于索引的API操作
data:image/s3,"s3://crabby-images/948d1/948d1a4cf88e2d6576c6ce731a22eedb40167da1" alt=""
索引的增删查(所示代码均自测成功):
package com.xupeng.esapi;
import org.elasticsearch.action.admin.indices.delete.DeleteIndexRequest;
import org.elasticsearch.action.support.master.AcknowledgedResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.client.indices.CreateIndexRequest;
import org.elasticsearch.client.indices.GetIndexRequest;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.io.IOException;
@SpringBootTest
class EsApiApplicationTests {
@Autowired
private RestHighLevelClient restHighLevelClient;
/**
* 创建索引
* @throws IOException
*/
@Test
void createIndex() throws IOException {
//1.创建索引请求
CreateIndexRequest request = new CreateIndexRequest("xupeng_index");
//2.客户端执行请求,请求后获得响应
restHighLevelClient.indices().create(request, RequestOptions.DEFAULT);
}
/**
* 获取索引
*/
@Test
void getIndex() throws IOException {
//1.获取索引请求
GetIndexRequest request = new GetIndexRequest("xupeng_index");
//2.获取索引
boolean isExist = restHighLevelClient.indices().exists(request, RequestOptions.DEFAULT);
System.out.println(isExist);
}
/**
* 删除索引
*/
@Test
void deleteIndex() throws IOException {
DeleteIndexRequest request = new DeleteIndexRequest("xupeng_index");
AcknowledgedResponse delete = restHighLevelClient.indices().delete(request, RequestOptions.DEFAULT);
System.out.println(delete.isAcknowledged());
}
}
5.关于文档的API操作
data:image/s3,"s3://crabby-images/c3b29/c3b29fb2bf2e227d178ed58fe5114f775a449805" alt=""
User:
package com.xupeng.esapi.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import org.springframework.stereotype.Component;
/**
* [一句话描述该类的功能]
*
* @author : [xupeng]
* @version : [v1.0]
* @createTime : [2021/7/14 19:25]
*/
@Data
@NoArgsConstructor
@AllArgsConstructor
@Component
public class User {
private String name;
private int age;
}
EsApiDocTests:
package com.xupeng.esapi;
import com.alibaba.fastjson.JSON;
import com.xupeng.esapi.pojo.User;
import org.elasticsearch.action.bulk.BulkRequest;
import org.elasticsearch.action.bulk.BulkResponse;
import org.elasticsearch.action.delete.DeleteRequest;
import org.elasticsearch.action.delete.DeleteResponse;
import org.elasticsearch.action.get.GetRequest;
import org.elasticsearch.action.get.GetResponse;
import org.elasticsearch.action.index.IndexRequest;
import org.elasticsearch.action.index.IndexResponse;
import org.elasticsearch.action.search.SearchRequest;
import org.elasticsearch.action.search.SearchResponse;
import org.elasticsearch.action.update.UpdateRequest;
import org.elasticsearch.action.update.UpdateResponse;
import org.elasticsearch.client.RequestOptions;
import org.elasticsearch.client.RestHighLevelClient;
import org.elasticsearch.common.unit.TimeValue;
import org.elasticsearch.common.xcontent.XContentType;
import org.elasticsearch.index.query.MatchAllQueryBuilder;
import org.elasticsearch.index.query.QueryBuilders;
import org.elasticsearch.index.query.TermQueryBuilder;
import org.elasticsearch.search.SearchHit;
import org.elasticsearch.search.builder.SearchSourceBuilder;
import org.elasticsearch.search.fetch.subphase.highlight.HighlightBuilder;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import java.io.IOException;
import java.util.ArrayList;
import java.util.concurrent.TimeUnit;
@SpringBootTest
class EsApiDocTests {
@Autowired
private RestHighLevelClient restHighLevelClient;
/**
* 添加文档
*
* @throws IOException
*/
@Test
void createDoc() throws IOException {
User user = new User("徐鹏", 3);
//创建请求
IndexRequest request = new IndexRequest("xupeng_index");
//规则 PUT xupeng_index/_doc/1
//id设置为1
request.id("1");
//请求时长1秒
request.timeout(TimeValue.timeValueSeconds(1));
//数据放入请求
request.source(JSON.toJSONString(user), XContentType.JSON);
//客户端发送请求
IndexResponse indexResponse = restHighLevelClient.index(request, RequestOptions.DEFAULT);
System.out.println(indexResponse.toString());
System.out.println(indexResponse.status());
}
/**
* 批量新增数据
*/
@Test
void batchCreateDoc() throws IOException {
BulkRequest bulkRequest = new BulkRequest();
bulkRequest.timeout("10s");
ArrayList<User> userList = new ArrayList<>();
userList.add(new User("xu1",2));
userList.add(new User("xu2",2));
userList.add(new User("xu3",2));
userList.add(new User("peng1",4));
userList.add(new User("peng2",4));
userList.add(new User("peng3",4));
for(int i = 0;i<userList.size();i++){
//批量更新和删除与之对应即可
bulkRequest.add(
new IndexRequest("xupeng_index")
.id(""+(i+1))
.source(JSON.toJSONString(userList.get(i)),XContentType.JSON)
);
BulkResponse bulkResponse = restHighLevelClient.bulk(bulkRequest,RequestOptions.DEFAULT);
System.out.println(bulkResponse);
System.out.println(bulkResponse.hasFailures());
}
}
/**
* 判断文档是否存在 GET xupeng_index/_doc/1
*
* @throws IOException
*/
@Test
void existDoc() throws IOException {
GetRequest getRequest = new GetRequest("xupeng_index", "1");
boolean isExist = restHighLevelClient.exists(getRequest, RequestOptions.DEFAULT);
System.out.println(isExist);
}
/**
* 根据ID查询信息 GET xupeng_index/_doc/1
*
* @throws IOException
*/
@Test
void getDoc() throws IOException {
GetRequest getRequest = new GetRequest("xupeng_index", "1");
GetResponse getResponse = restHighLevelClient.get(getRequest, RequestOptions.DEFAULT);
System.out.println(getResponse.getSourceAsString());
System.out.println(getResponse);
}
/**
* 修改信息
*
* @throws IOException
*/
@Test
void updateDoc() throws IOException {
UpdateRequest updateRequest = new UpdateRequest("xupeng_index", "1");
updateRequest.timeout("1s");
User user = new User("徐鹏2号",16);
updateRequest.doc(JSON.toJSONString(user),XContentType.JSON);
UpdateResponse updateResponse = restHighLevelClient.update(updateRequest,RequestOptions.DEFAULT);
System.out.println(updateResponse);
}
/**
* 删除信息
*
* @throws IOException
*/
@Test
void deleteDoc() throws IOException {
DeleteRequest deleteRequest = new DeleteRequest("xupeng_index", "1");
deleteRequest.timeout("1s");
DeleteResponse deleteResponse = restHighLevelClient.delete(deleteRequest,RequestOptions.DEFAULT);
System.out.println(deleteRequest);
}
/**
* 自定义条件查询
* @throws IOException
*/
@Test
void searchDoc() throws IOException {
SearchRequest searchRequest = new SearchRequest("xupeng_index");
//查询条件,使用QueryBuilders工具实现
SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();
//精确查询
//QueryBuilders.termQuery精确
//QueryBuilders.matchAllQuery()匹配所有
TermQueryBuilder termQueryBuilder = QueryBuilders.termQuery("name","xu1");
// MatchAllQueryBuilder matchAllQueryBuilder = QueryBuilders.matchAllQuery();
searchSourceBuilder.query(termQueryBuilder);
searchSourceBuilder.timeout(new TimeValue(60, TimeUnit.SECONDS));
//分页
searchSourceBuilder.from(2);
searchSourceBuilder.size(10);
//高亮
HighlightBuilder highlightBuilder = new HighlightBuilder();
highlightBuilder.field("title");
highlightBuilder.preTags("<spna style='color:red'>");
highlightBuilder.postTags("</span>");
highlightBuilder.requireFieldMatch(false);//多个高亮显示
searchSourceBuilder.highlighter(highlightBuilder);
searchRequest.source(searchSourceBuilder);
SearchResponse searchResponse = restHighLevelClient.search(searchRequest,RequestOptions.DEFAULT);
System.out.println(JSON.toJSONString(searchResponse.getHits()));
for(SearchHit searchHit:searchResponse.getHits()){
System.out.println(searchHit.getSourceAsMap());
}
}
}
五、打赏请求
如果本篇博客对您有所帮助,打赏一点呗,谢谢了呢~
data:image/s3,"s3://crabby-images/5ad2a/5ad2af5d40e30e8c391d604d3d6aae6f1b237351" alt=""
|