第2章 Elasticsearch入门

news2025/1/7 10:41:56

2.1 Elasticsearch 安装

2 . 1 .1 下载软件

Elasticsearch的官方地址:www.elastic.co/cn/

Elasticsearch最新的版本是7.11.2(截止2021.3.10),我们选择7.8.0版本(最新版本半年前的版本)

下载地址:www.elastic.co/cn/download…

Elasticsearch分为Linux和Windows版本,基于我们主要学习的是Elasticsearch的Java客户端的使用,所以课程中使用的是安装较为简便的Windows版本。

2 . 1 . 2 安装软件

Windows版的Elasticsearch的安装很简单,解压即安装完毕,解压后的Elasticsearch的目录结构如下

目录含义
bin可执行脚本目录
config配置目录
jdk内置JDK目录
lib类库
logs日志目录
modules模块目录
plugins插件目录

解压后,进入bin文件目录,点击elasticsearch.bat文件启动ES服务

注意: 9300 端口为 Elastic s earch 集群间组件的通信端口, 9200 端口为浏览器访问的http协议RESTful端口。

打开浏览器(推荐使用谷歌浏览器),输入地址:http://localhost:9200,测试结果

2 . 1 . 3 问题解决

Ø Elasticsearch是使用java开发的,且7.8版本的ES需要JDK版本1.8以上,默认安装包带有jdk环境,如果系统配置JAVA_HOME,那么使用系统默认的JDK,如果没有配置使用自带的JDK,一般建议使用系统配置的JDK。

Ø 双击启动窗口闪退,通过路径访问追踪错误,如果是“空间不足”,请修改config/jvm.options配置文件

# 设置JVM初始内存为1G。此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存

# Xms represents the initial size of total heap space

# 设置JVM最大可用内存为1G

# Xmx represents the maximum size of total heap space
-Xms1g
-Xmx1g
复制代码

2. 2 Elasticsearch基本操作

2 . 2 . 1 RESTful

REST 指的是一组架构约束条件和原则。满足这些约束条件和原则的应用程序或设计就是 RESTful。Web 应用程序最重要的 REST 原则是,客户端和服务器之间的交互在请求之间是无状态的。从客户端到服务器的每个请求都必须包含理解请求所必需的信息。如果服务器在请求之间的任何时间点重启,客户端不会得到通知。此外,无状态请求可以由任何可用服务器回答,这十分适合云计算之类的环境。客户端可以缓存数据以改进性能。

在服务器端,应用程序状态和功能可以分为各种资源。资源是一个有趣的概念实体,它向客户端公开。资源的例子有:应用程序对象、数据库记录、算法等等。每个资源都使用 URI (Universal Resource Identifier) 得到一个唯一的地址。所有资源都共享统一的接口,以便在客户端和服务器之间传输状态。使用的是标准的 HTTP 方法,比如 GET、PUT、POST 和 DELETE。

在 REST 样式的 Web 服务中,每个资源都有一个地址。资源本身都是方法调用的目标,方法列表对所有资源都是一样的。这些方法都是标准方法,包括 HTTP GET、POST、PUT、DELETE,还可能包括 HEAD 和 OPTIONS。简单的理解就是,如果想要访问互联网上的资源,就必须向资源所在的服务器发出请求,请求体中必须包含资源的网络路径,以及对资源进行的操作(增删改查)。

2 . 2 . 2客户端安装****

如果直接通过浏览器向Elasticsearch服务器发请求,那么需要在发送的请求中包含HTTP标准的方法,而HTTP 的大部分特性且仅支持 GET和POST 方法。所以为了能方便地进行客户端的访问,可以使用Postman软件

Postman是一款强大的网页调试工具,提供功能强大的Web API 和 HTTP 请求调试。软件功能强大,界面简洁明晰、操作方便快捷,设计得很人性化。Postman中文版能够发送任何类型的HTTP 请求 (GET, HEAD, POST, PUT..),不仅能够表单提交,且可以附带任意类型请求体。

Postman官网:www.getpostman.com

Postman下载:www.getpostman.com/apps

2 . 2 . 3数据格式

Elasticsearch是面向文档型数据库,一条数据在这里就是一个文档。为了方便大家理解,我们将Elasticsearch里存储文档数据和关系型数据库MySQL存储数据的概念进行一个类比

ES里的Index可以看做一个库,而Types相当于表,Documents则相当于表的行。

这里Types的概念已经被逐渐弱化,Elasticsearch 6.X中,一个index下已经只能包含一个type,Elasticsearch 7.X中, Type的概念已经被删除了。

6用JSON作为文档序列化的格式,比如一条用户信息:

{

    "name" : "John",

    "sex" : "Male",

    "age" : 25,

    "birthDate": "1990/05/01",

    "about" : "I love to go rock climbing",

    "interests": [ "sports", "music" ]

}
复制代码

2 . 2 . 4 HTTP操作

2 . 2 . 4 .1 索引操作

1) 创建索引****

对比关系型数据库,创建索引就等同于创建数据库

在 Postman中,向ES服务器发PUT请求 :http://127.0.0.1:9200/shopping

请求后,服务器返回响应

{

    "acknowledged"【响应结果】: true, # true操作成功

    "shards_acknowledged"【分片结果】: true, # 分片操作成功

    "index"【索引名称】: "shopping"

}

# 注意:创建索引库的分片数默认1片,在7.0.0之前的Elasticsearch版本中,默认5片
复制代码

如果重复添加索引,会返回错误信息

2) 查看所有索引

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/_cat/indices?v

这里请求路径中的_cat表示查看的意思,indices表示索引,所以整体含义就是查看当前ES服务器中的所有索引,就好像MySQL中的show tables的感觉,服务器响应结果如下

表头含义
health当前服务器健康状态:green(集群完整) yellow(单点正常、集群不完整) red(单点不正常)
status索引打开、关闭状态
index索引名
uuid索引统一编号
pri主分片数量
rep副本数量
docs.count可用文档数量
docs.deleted文档删除状态(逻辑删除)
store.size主分片和副分片整体占空间大小
pri.store.size主分片占空间大小

3) 查看单个索引

在 Postman中,向ES服务器发GET请http://127.0.0.1:9200/shopping

查看索引向ES服务器发送的请求路径和创建索引是一致的。但是HTTP方法不一致。这里可以体会一下RESTful的意义, 请求后,服务器响应结果如下:

{

    "shopping"【索引名】: {        

        "aliases"【别名】: {},

        "mappings"【映射】: {},

        "settings"【设置】: {

            "index"【设置 - 索引】: {

                "creation_date"【设置 - 索引 - 创建时间】: "1614265373911",

                "number_of_shards"【设置 - 索引 - 主分片数量】: "1",

                "number_of_replicas"【设置 - 索引 - 副分片数量】: "1",

                "uuid"【设置 - 索引 - 唯一标识】: "eI5wemRERTumxGCc1bAk2A",

                "version"【设置 - 索引 - 版本】: {

                    "created": "7080099"

                },

                "provided_name"【设置 - 索引 - 名称】: "shopping"

            }

        }

    }

}
复制代码

4) 删除索引****

在 Postman中,向ES服务器发DELETE请求 :http://127.0.0.1:9200/shopping

重新访问索引时,服务器返回响应:索引不存在

2 . 2 . 4 . 2 文档操作

1) 创建文档

索引已经创建好了,接下来我们来创建文档,并添加数据。这里的文档可以类比为关系型数据库中的表数据,添加的数据格式为JSON格式

在 Postman中,向ES服务器发POST请求 :http://127.0.0.1:9200/shopping/_doc

请求体内容为:

{

    "title":"小米手机",

    "category":"小米",

    "images":"http://www.gulixueyuan.com/xm.jpg",

    "price":3999.00

}
复制代码

此处发送请求的方式必须为POST,不能是PUT,否则会发生错误

服务器响应结果如下:

{

    "_index"【索引】: "shopping",

    "_type"【类型-文档】: "_doc",

    "_id"【唯一标识】: "Xhsa2ncBlvF_7lxyCE9G", #可以类比为MySQL中的主键,随机生成

    "_version"【版本】: 1,

    "result"【结果】: "created", #这里的create表示创建成功

    "_shards"【分片】: {

        "total"【分片 - 总数】: 2,

        "successful"【分片 - 成功】: 1,

        "failed"【分片 - 失败】: 0

    },

    "_seq_no": 0,

    "_primary_term": 1

}
复制代码

上面的数据创建后,由于没有指定数据唯一性标识(ID),默认情况下,ES服务器会随机生成一个。

如果想要自定义唯一性标识,需要在创建时指定:http://127.0.0.1:9200/shopping/_doc/1

 

此处需要注意:如果增加数据时明确数据主键,那么请求方式也可以为PUT

2) 查看文档

查看文档时,需要指明文档的唯一性标识,类似于MySQL中数据的主键查询

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/shopping/_doc/1

查询成功后,服务器响应结果:

{

    "_index"【索引】: "shopping",

    "_type"【文档类型】: "_doc",

    "_id": "1",

    "_version": 2,

    "_seq_no": 2,

    "_primary_term": 2,

    "found"【查询结果】: true, # true表示查找到,false表示未查找到

    "_source"【文档源信息】: {

        "title": "华为手机",

        "category": "华为",

        "images": "http://www.gulixueyuan.com/hw.jpg",

        "price": 4999.00

    }

}
复制代码

3) 修改文档****

和新增文档一样,输入相同的URL地址请求,如果请求体变化,会将原有的数据内容覆盖

在 Postman中,向ES服务器发POST请求 :

http://127.0.0.1:9200/shopping/_doc/1
复制代码

请求体内容为:

{

    "title":"华为手机",

    "category":"华为",

    "images":"http://www.gulixueyuan.com/hw.jpg",

    "price":4999.00

}
复制代码

修改成功后,服务器响应结果:

{

    "_index": "shopping",

    "_type": "_doc",

    "_id": "1",

    "_version"【版本】: 2,

    "result"【结果】: "updated", # updated表示数据被更新

    "_shards": {

        "total": 2,

        "successful": 1,

        "failed": 0

    },

    "_seq_no": 2,

    "_primary_term": 2

}
复制代码

4) 修改字段

修改数据时,也可以只修改某一给条数据的局部信息

在 Postman中,向ES服务器发POST请求 :http://127.0.0.1:9200/shopping/_update/1

请求体内容为:

{

  "doc": {

    "price":3000.00

  }

}
复制代码

修改成功后,服务器响应结果:

根据唯一性标识,查询文档数据,文档数据已经更新

5) 删除文档

删除一个文档不会立即从磁盘上移除,它只是被标记成已删除(逻辑删除)。

在 Postman中,向ES服务器发DELETE请求 :http://127.0.0.1:9200/shopping/_doc/1

删除成功,服务器响应结果:

{

    "_index": "shopping",

    "_type": "_doc",

    "_id": "1",

    "_version"【版本】: 4, #对数据的操作,都会更新版本

    "result"【结果】: "deleted", # deleted表示数据被标记为删除

    "_shards": {

        "total": 2,

        "successful": 1,

        "failed": 0

    },

    "_seq_no": 4,

    "_primary_term": 2

}
复制代码

删除后再查询当前文档信息

如果删除一个并不存在的文档

{

    "_index": "shopping",

    "_type": "_doc",

    "_id": "1",

    "_version": 1,

    "result"【结果】: "not_found", # not_found表示未查找到

    "_shards": {

        "total": 2,

        "successful": 1,

        "failed": 0

    },

    "_seq_no": 5,

    "_primary_term": 2

}
复制代码

6) 条件删除文档

一般删除数据都是根据文档的唯一性标识进行删除,实际操作时,也可以根据条件对多条数据进行删除

首先分别增加多条数据:

{

    "title":"小米手机",

    "category":"小米",

    "images":"http://www.gulixueyuan.com/xm.jpg",

    "price":4000.00

}

 

{

    "title":"华为手机",

    "category":"华为",

    "images":"http://www.gulixueyuan.com/hw.jpg",

    "price":4000.00

}
复制代码

向ES服务器发POST请求 : http://127.0.0.1:9200/shopping/_delete_by_query 请求体内容为:

{

  "query":{

    "match":{

      "price":4000.00

    }

  }

}
复制代码

删除成功后,服务器响应结果:

{

    "took"【耗时】: 175,

    "timed_out"【是否超时】: false,

    "total"【总数】: 2,

    "deleted"【删除数量】: 2,

    "batches": 1,

    "version_conflicts": 0,

    "noops": 0,

    "retries": {

        "bulk": 0,

        "search": 0

    },

    "throttled_millis": 0,

    "requests_per_second": -1.0,

    "throttled_until_millis": 0,

    "failures": []

}
复制代码

2 . 2 . 4 . 3 映射操作

有了索引库,等于有了数据库中的database。

接下来就需要建索引库(index)中的映射了,类似于数据库(database)中的表结构(table)。创建数据库表需要设置字段名称,类型,长度,约束等;索引库也一样,需要知道这个类型下有哪些字段,每个字段有哪些约束信息,这就叫做映射(mapping)。

1) 创建映射****

在 Postman中,向ES服务器发PUT请求 :http://127.0.0.1:9200/student/_mapping

请求体内容为:

{

  "properties": {

    "name":{

      "type": "text",

      "index": true

    },

    "sex":{

      "type": "text",

      "index": false

    },

    "age":{

      "type": "long",

      "index": false

    }

  }

}
复制代码

服务器响应结果如下:

映射数据说明:

  • 字段名:任意填写,下面指定许多属性,例如:title、subtitle、images、price

  • type:类型,Elasticsearch中支持的数据类型非常丰富,说几个关键的:

    • String类型,又分两种:
      • text:可分词
      • keyword:不可分词,数据会作为完整字段进行匹配
  • Numerical:数值类型,分两类

    • 基本数据类型:long、integer、short、byte、double、float、half_float
    • 浮点数的高精度类型:scaled_float
  • Date:日期类型

  • Array:数组类型

  • Object:对象

  • index:是否索引,默认为true,也就是说你不进行任何配置,所有字段都会被索引。

  • true:字段会被索引,则可以用来进行搜索

  • false:字段不会被索引,不能用来搜索

  • store:是否将数据进行独立存储,默认为false

    原始的文本会存储在_source里面,默认情况下其他提取出来的字段都不是独立存储的,是从_source里面提取出来的。当然你也可以独立的存储某个字段,只要设置"store": true即可,获取独立存储的字段要比从_source中解析快得多,但是也会占用更多的空间,所以要根据实际业务需求来设置。

  • analyzer:分词器,这里的ik_max_word即使用ik分词器,后面会有专门的章节学习

2) 查看映射

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student /_mapping****

服务器响应结果如下:

3) 索引映射关联

在 Postman中,向ES服务器发PUT请求 :http://127.0.0.1:9200/student1

{

  "settings": {},

  "mappings": {

  "properties": {

"name":{

  "type": "text",

  "index": true

  

},

"sex":{

  "type": "text",

  "index": false

},

"age":{

  "type": "long",

  "index": false

}

  }

  }

}
复制代码

服务器响应结果如下:

2 . 2 . 4 . 4 高级查询

Elasticsearch提供了基于JSON提供完整的查询DSL来定义查询

定义数据 :

# POST /student/_doc/1001

{

"name":"zhangsan",

"nickname":"zhangsan",

    "sex":"男",

    "age":30

}

# POST /student/_doc/1002

{

"name":"lisi",

"nickname":"lisi",

    "sex":"男",

    "age":20

}

# POST /student/_doc/1003

{

"name":"wangwu",

    "nickname":"wangwu",

    "sex":"女",

    "age":40

}

# POST /student/_doc/1004

{

"name":"zhangsan1",

"nickname":"zhangsan1",

    "sex":"女",

    "age":50

}

# POST /student/_doc/1005

{

"name":"zhangsan2",

"nickname":"zhangsan2",

    "sex":"女",

    "age":30

}
复制代码

1) 查询所有文档****

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match_all": {}

  }

}

# "query":这里的query代表一个查询对象,里面可以有不同的查询属性

# "match_all":查询类型,例如:match_all(代表查询所有), match,term , range 等等

# {查询条件}:查询条件会根据类型的不同,写法也有差异
复制代码

服务器响应结果如下:

{

  "took【查询花费时间,单位毫秒】" : 1116,

  "timed_out【是否超时】" : false,

  "_shards【分片信息】" : {

    "total【总数】" : 1,

    "successful【成功】" : 1,

    "skipped【忽略】" : 0,

    "failed【失败】" : 0

  },

  "hits【搜索命中结果】" : {

     "total"【搜索条件匹配的文档总数】: {

         "value"【总命中计数的值】: 3,

         "relation"【计数规则】: "eq" # eq 表示计数准确, gte表示计数不准确

     },

    "max_score【匹配度分值】" : 1.0,

    "hits【命中结果集合】" : [

       。。。

      }

    ]

  }

}
复制代码

2) 匹配查询

match匹配类型查询,会把查询条件进行分词,然后进行查询,多个词条之间是or的关系

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match": {

        "name":"zhangsan"

    }

  }

}
复制代码

服务器响应结果为:

3) 字段匹配查询

multi_match与match类似,不同的是它可以在多个字段中查询。

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "multi_match": {

        "query": "zhangsan",

        "fields": ["name","nickname"]

    }

  }

}
复制代码

服务器响应结果:

4) 关键字精确查询

term查询,精确的关键词匹配查询,不对查询条件进行分词。

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "term": {

      "name": {

        "value": "zhangsan"

      }

    }

  }

}
复制代码

服务器响应结果:

5) 多关键字精确查询

terms 查询和 term 查询一样,但它允许你指定多值进行匹配。

如果这个字段包含了指定值中的任何一个值,那么这个文档满足条件,类似于mysql的in

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "terms": {

      "name": ["zhangsan","lisi"]

    }

  }

}
复制代码

服务器响应结果:

6) 指定查询字段****

默认情况下,Elasticsearch在搜索的结果中,会把文档中保存在_source的所有字段都返回。

如果我们只想获取其中的部分字段,我们可以添加_source的过滤

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "_source": ["name","nickname"],  

  "query": {

    "terms": {

      "nickname": ["zhangsan"]

    }

  }

}
复制代码

服务器响应结果:

7) 过滤字段

我们也可以通过:

Ø includes:来指定想要显示的字段

Ø excludes:来指定不想要显示的字段

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "_source": {

    "includes": ["name","nickname"]

  },  

  "query": {

    "terms": {

      "nickname": ["zhangsan"]

    }

  }

}
复制代码

服务器响应结果:

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "_source": {

    "excludes": ["name","nickname"]

  },  

  "query": {

    "terms": {

      "nickname": ["zhangsan"]

    }

  }

}
复制代码

服务器响应结果:

8) 组合查询****

bool把各种其它查询通过must(必须 )、must_not(必须不)、should(应该)的方式进行组合

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "bool": {

      "must": [

        {

          "match": {

            "name": "zhangsan"

          }

        }

      ],

      "must_not": [

        {

          "match": {

            "age": "40"

          }

        }

      ],

      "should": [

        {

          "match": {

            "sex": "男"

          }

        }

      ]

    }

  }

}
复制代码

服务器响应结果:

9) 范围查询

range 查询找出那些落在指定区间内的数字或者时间。range查询允许以下字符

操作符说明
gt大于>
gte大于等于>=
lt小于<
lte小于等于<=

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "range": {

      "age": {

        "gte": 30,

        "lte": 35

      }

    }

  }

}
复制代码

服务器响应结果:

10) 模糊查询

返回包含与搜索字词相似的字词的文档。

编辑距离是将一个术语转换为另一个术语所需的一个字符更改的次数。这些更改可以包括:

l 更改字符(box → fox)

l 删除字符(black → lack)

l 插入字符(sic → sick)

l 转置两个相邻字符(act → cat)

为了找到相似的术语,fuzzy查询会在指定的编辑距离内创建一组搜索词的所有可能的变体或扩展。然后查询返回每个扩展的完全匹配。

通过fuzziness修改编辑距离。一般使用默认值AUTO,根据术语的长度生成编辑距离。

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "fuzzy": {

      "title": {

        "value": "zhangsan"

      }

    }

  }

}
复制代码

服务器响应结果:

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "fuzzy": {

      "title": {

        "value": "zhangsan",

"fuzziness": 2

      }

    }

  }

}
复制代码

服务器响应结果:

11) 单字段排序

sort 可以让我们按照不同的字段进行排序,并且通过order指定排序的方式。desc降序,asc升序。

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match": {

        "name":"zhangsan"

    }

  },

  "sort": [{

    "age": {

        "order":"desc"

    }

  }]

}
复制代码

服务器响应结果:

12) 多字段排序

假定我们想要结合使用 age和 _score进行查询,并且匹配的结果首先按照年龄排序,然后按照相关性得分排序

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match_all": {}

  },

  "sort": [

    {

      "age": {

        "order": "desc"

      }

    },

    {

      "_score":{

        "order": "desc"

      }

    }

  ]

}
复制代码

服务器响应结果:

13) 高亮查询

在进行关键字搜索时,搜索出的内容中的关键字会显示不同的颜色,称之为高亮。

Ø 在百度搜索"京东"

Elasticsearch可以对查询内容中的关键字部分,进行标签和样式(高亮)的设置。

在使用match查询的同时,加上一个highlight属性:

l pre_tags:前置标签

l post_tags:后置标签

l fields:需要高亮的字段

l title:这里声明title字段需要高亮,后面可以为这个字段设置特有配置,也可以空

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match": {

      "name": "zhangsan"

    }

  },

  "highlight": {

    "pre_tags": "<font color='red'>",

    "post_tags": "</font>",

    "fields": {

      "name": {}

    }

  }

}
复制代码

服务器响应结果:

14) 分页查询

from:当前页的起始索引,默认从0开始。 from = (pageNum - 1) * size

size:每页显示多少条

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

  "query": {

    "match_all": {}

  },

  "sort": [

    {

      "age": {

        "order": "desc"

      }

    }

  ],

  "from": 0,

  "size": 2

}
复制代码

服务器响应结果:

15) 聚合查询

聚合允许使用者对es文档进行统计分析,类似与关系型数据库中的group by,当然还有很多其他的聚合,例如取最大值、平均值等等。

Ø 对某个字段取最大值max

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "max_age":{

        "max":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

Ø 对某个字段取最小值min

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "min_age":{

        "min":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

Ø 对某个字段求和sum

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "sum_age":{

        "sum":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

Ø 对某个字段取平均值avg

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "avg_age":{

        "avg":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

Ø 对某个字段的值进行去重之后再取总数

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "distinct_age":{

        "cardinality":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果: Ø State聚合

stats聚合,对某个字段一次性返回count,max,min,avg和sum五个指标

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "stats_age":{

        "stats":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

16) 桶聚合查询

桶聚和相当于sql中的group by语句

Ø terms聚合,分组统计

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "age_groupby":{

        "terms":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

Ø 在terms分组下再进行聚合

在 Postman中,向ES服务器发GET请求 :http://127.0.0.1:9200/student/_search

{

    "aggs":{

      "age_groupby":{

        "terms":{"field":"age"}

      }

    },

    "size":0

}
复制代码

服务器响应结果:

2 . 2 . 5 Java API操作

Elasticsearch软件是由Java语言开发的,所以也可以通过Java API的方式对Elasticsearch服务进行访问

2 . 2 . 5 .1 创建Maven项目

我们在IDEA开发工具中创建Maven项目(模块也可)ES

修改pom文件,增加Maven依赖关系

<dependencies>

    <dependency>

        <groupId>org.elasticsearch</groupId>

        <artifactId>elasticsearch</artifactId>

        <version>**7.8.0**</version>

    </dependency>

    <!-- elasticsearch的客户端 -->

    <dependency>

        <groupId>org.elasticsearch.client</groupId>

        <artifactId>elasticsearch-rest-high-level-client</artifactId>

        <version>**7.8.0**</version>

    </dependency>

    <!-- elasticsearch依赖2.x的log4j -->

    <dependency>

        <groupId>org.apache.logging.log4j</groupId>

        <artifactId>log4j-api</artifactId>

        <version>2.8.2</version>

    </dependency>

    <dependency>

        <groupId>org.apache.logging.log4j</groupId>

        <artifactId>log4j-core</artifactId>

        <version>2.8.2</version>

</dependency>

<dependency>

<groupId>com.fasterxml.jackson.core</groupId>

<artifactId>jackson-databind</artifactId>

<version>2.9.9</version>

</dependency>

    <!-- junit单元测试 -->

    <dependency>

        <groupId>junit</groupId>

        <artifactId>junit</artifactId>

        <version>4.12</version>

    </dependency>

</dependencies>
复制代码

2 . 2 . 5 . 2 客户端对象

创建com.atguigu.es.test.Elasticsearch01_Client类,代码中创建Elasticsearch客户端对象

因为早期版本的客户端对象已经不再推荐使用,且在未来版本中会被删除,所以这里我们采用高级REST客户端对象

// 创建客户端对象

RestHighLevelClient client = new RestHighLevelClient(

RestClient.builder(new HttpHost("localhost", 9200, "http"))

);

...
// 关闭客户端连接

client.close();
复制代码

注意: 9200端口为Elasticsearch的Web通信端口 localhost为启动ES服务的主机名 执行代码,查看控制台信息:

2 . 2 . 5 . 3 索引操作

ES服务器正常启动后,可以通过Java API 客户端对象对ES索引进行操作

1) 创建索引

// 创建索引 - 请求对象

CreateIndexRequest request = new CreateIndexRequest("user");

// 发送请求,获取响应

CreateIndexResponse response = client.indices().create(request, RequestOptions.DEFAULT);

boolean acknowledged = response.isAcknowledged();

// 响应状态

System.out.println("操作状态 = " + acknowledged);
复制代码

操作结果:

2) 查看索引

// 查询索引 - 请求对象

GetIndexRequest request = new GetIndexRequest("user");

// 发送请求,获取响应

GetIndexResponse response = client.indices().get(request, RequestOptions.DEFAULT);

System.out.println("aliases:"+response.getAliases());

System.out.println("mappings:"+response.getMappings());

System.out.println("settings:"+response.getSettings());
复制代码

操作结果:

3) 删除索引

// 删除索引 - 请求对象

DeleteIndexRequest request = new DeleteIndexRequest("user");

// 发送请求,获取响应

AcknowledgedResponse response = client.indices().delete(request, RequestOptions.DEFAULT);

// 操作结果

System.out.println("操作结果 : " + response.isAcknowledged());
复制代码

操作结果:

2 . 2 . 5 . 4 文档操作

1) 新增文档

创建数据模型

class User {                         

    private String name;             

    private Integer age;             

    private String sex;              

                                     

    public String getName() {        

        return name;                 

    }                                

    public void setName(String name)

        this.name = name;            

    }                                

    public Integer getAge() {        

        return age;                  

    }                                

    public void setAge(Integer age) {

        this.age = age;              

    }                                

    public String getSex() {         

        return sex;                  

    }                                

    public void setSex(String sex) {

        this.sex = sex;              

    }                                

}                                    
复制代码

创建数据,添加到文档中

// 新增文档 - 请求对象

IndexRequest request = new IndexRequest();

// 设置索引及唯一性标识

request.index("user").id("1001");

// 创建数据对象

User user = new User();

user.setName("zhangsan");

user.setAge(30);

user.setSex("男");

ObjectMapper objectMapper = new ObjectMapper();

String productJson = objectMapper.writeValueAsString(user);

// 添加文档数据,数据格式为JSON格式

request.source(productJson,XContentType.JSON);

// 客户端发送请求,获取响应对象

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

3.打印结果信息

System.out.println("_index:" + response.getIndex());

System.out.println("_id:" + response.getId());

System.out.println("_result:" + response.getResult());                           
复制代码

操作结果:

2) 修改文档

// 修改文档 - 请求对象

UpdateRequest request = new UpdateRequest();

// 配置修改参数

request.index("user").id("1001");

// 设置请求体,对数据进行修改

request.doc(XContentType.JSON, "sex", "女");

// 客户端发送请求,获取响应对象

UpdateResponse response = client.update(request, RequestOptions.DEFAULT);

System.out.println("_index:" + response.getIndex());

System.out.println("_id:" + response.getId());

System.out.println("_result:" + response.getResult());

复制代码

执行结果:

3) 查询文档

//1.创建请求对象

GetRequest request = new GetRequest().index("user").id("1001");

//2.客户端发送请求,获取响应对象

GetResponse response = client.get(request, RequestOptions.DEFAULT);

3.打印结果信息

System.out.println("_index:" + response.getIndex());

System.out.println("_type:" + response.getType());

System.out.println("_id:" + response.getId());

System.out.println("source:" + response.getSourceAsString());
复制代码

执行结果为:

4) 删除文档

//创建请求对象

DeleteRequest request = new DeleteRequest().index("user").id("1");

//客户端发送请求,获取响应对象

DeleteResponse response = client.delete(request, RequestOptions.DEFAULT);

//打印信息

System.out.println(response.toString());
复制代码

执行结果为:

5) 批量操作****

Ø 批量新增:

//创建批量新增请求对象

BulkRequest request = new BulkRequest();

request.add(new IndexRequest().index("user").id("1001").source(XContentType.JSON, "name", "zhangsan"));

request.add(new IndexRequest().index("user").id("1002").source(XContentType.JSON, "name", "lisi"));

request.add(new IndexRequest().index("user").id("1003").source(XContentType.JSON, "name", "wangwu"));

//客户端发送请求,获取响应对象

BulkResponse responses = client.bulk(request, RequestOptions.DEFAULT);

//打印结果信息

System.out.println("took:" + responses.getTook());

System.out.println("items:" + responses.getItems());
复制代码

执行结果为:

Ø 批量删除:

//创建批量删除请求对象

BulkRequest request = new BulkRequest();

request.add(new DeleteRequest().index("user").id("1001"));

request.add(new DeleteRequest().index("user").id("1002"));

request.add(new DeleteRequest().index("user").id("1003"));

//客户端发送请求,获取响应对象

BulkResponse responses = client.bulk(request, RequestOptions.DEFAULT);

//打印结果信息

System.out.println("took:" + responses.getTook());

System.out.println("items:" + responses.getItems());
复制代码

执行结果为:

2 . 2 . 5 . 5 高级查询

1) 请求体查询****

Ø 查询所有索引数据

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

// 查询所有数据

sourceBuilder.query(QueryBuilders.**matchAllQuery**());

request.source(sourceBuilder);

 

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø term查询,查询条件为关键字

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.query(QueryBuilders.**termQuery**("age", "30"));

request.source(sourceBuilder);

 

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø 分页查询

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.query(QueryBuilders.matchAllQuery());

 

// 分页查询

// 当前页其实索引(第一条数据的顺序号),from

sourceBuilder.from(0);

// 每页显示多少条size

sourceBuilder.size(2);

 

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø 数据排序

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.query(QueryBuilders.matchAllQuery());

 

// 排序

sourceBuilder.sort("age", SortOrder.ASC);

 

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø 过滤字段

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.query(QueryBuilders.matchAllQuery());

 

//查询字段过滤

String[] excludes = {};

String[] includes = {"name", "age"};

sourceBuilder.fetchSource(includes, excludes);

 

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø Bool查询

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

 

BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();

// 必须包含

boolQueryBuilder.must(QueryBuilders.matchQuery("age", "30"));

// 一定不含

boolQueryBuilder.mustNot(QueryBuilders.matchQuery("name", "zhangsan"));

// 可能包含

boolQueryBuilder.should(QueryBuilders.matchQuery("sex", "男"));

 

sourceBuilder.query(boolQueryBuilder);

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø 范围查询

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

 

RangeQueryBuilder rangeQuery = QueryBuilders.rangeQuery("age");

// 大于等于

rangeQuery.gte("30");

// 小于等于

rangeQuery.lte("40");

 

sourceBuilder.query(rangeQuery);

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

Ø 模糊查询

// 创建搜索请求对象

SearchRequest request = new SearchRequest();

request.indices("student");

 

// 构建查询的请求体

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

 

sourceBuilder.query(QueryBuilders.fuzzyQuery("name","zhangsan").fuzziness(Fuzziness.ONE));

request.source(sourceBuilder);

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

// 查询匹配

SearchHits hits = response.getHits();

System.out.println("took:" + response.getTook());

System.out.println("timeout:" + response.isTimedOut());

System.out.println("total:" + hits.getTotalHits());

System.out.println("MaxScore:" + hits.getMaxScore());

System.out.println("hits========>>");

for (SearchHit hit : hits) {

//输出每条查询的结果信息

System.out.println(hit.getSourceAsString());

}

System.out.println("<<========");
复制代码

2) 高亮查询****

// 高亮查询

SearchRequest request = new SearchRequest().indices("student");

//2.创建查询请求体构建器

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

//构建查询方式:高亮查询

TermsQueryBuilder termsQueryBuilder = QueryBuilders.termsQuery("name","zhangsan");

//设置查询方式

sourceBuilder.query(termsQueryBuilder);

//构建高亮字段

HighlightBuilder highlightBuilder = new HighlightBuilder();

highlightBuilder.preTags("<font color='red'>");//设置标签前缀

highlightBuilder.postTags("</font>");//设置标签后缀

highlightBuilder.field("name");//设置高亮字段

//设置高亮构建对象

sourceBuilder.highlighter(highlightBuilder);

//设置请求体

request.source(sourceBuilder);

//3.客户端发送请求,获取响应对象

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

 

//4.打印响应结果

SearchHits hits = response.getHits();

System.out.println("took::"+response.getTook());

System.out.println("time_out::"+response.isTimedOut());

System.out.println("total::"+hits.getTotalHits());

System.out.println("max_score::"+hits.getMaxScore());

System.out.println("hits::::>>");

for (SearchHit hit : hits) {

String sourceAsString = hit.getSourceAsString();

System.out.println(sourceAsString);

//打印高亮结果

Map<String, HighlightField> highlightFields = hit.getHighlightFields();

System.out.println(highlightFields);

}

System.out.println("<<::::");
复制代码

3) 聚合查询

Ø 最大年龄

// 高亮查询

SearchRequest request = new SearchRequest().indices("student");

 

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.aggregation(AggregationBuilders.max("maxAge").field("age"));

//设置请求体

request.source(sourceBuilder);

//3.客户端发送请求,获取响应对象

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

 

//4.打印响应结果

SearchHits hits = response.getHits();

System.out.println(response);
复制代码

Ø 分组统计

// 高亮查询

SearchRequest request = new SearchRequest().indices("student");

 

SearchSourceBuilder sourceBuilder = new SearchSourceBuilder();

sourceBuilder.aggregation(AggregationBuilders.terms("age_groupby").field("age"));

 

//设置请求体

request.source(sourceBuilder);

//3.客户端发送请求,获取响应对象

SearchResponse response = client.search(request, RequestOptions.DEFAULT);

 

//4.打印响应结果

SearchHits hits = response.getHits();

System.out.println(response);
复制代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/28593.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

贝叶斯网络

贝叶斯网络的独立性&#xff1a; 当一个结点G的父节点已知的时候&#xff0c;该结点G与其所有非后代结点条件独立 交叉因果推断&#xff1a;如上述图中的例子,对于P&#xff08;i | g | d&#xff09;等于说是中D到I 这条路径中&#xff0c;做半边的路径是顺着箭头走的&#x…

表白墙(前端+后端+数据库)

目录 一、创建项目 1、创建maven项目&#xff0c;引入依赖 2、创建目录结构 二、前端代码 1、页面内容和样式 2、提交按钮的点击事件 3、发送GET请求 三、数据库 四、后端代码 1、重写doPost方法 1.1 创建Message类 1.2 重写doPost方法 1.3 实现save方法 2、重写…

你需要知道的50颗卫星:地球卫星清单

开放数据卫星 1陆地卫星 地球资源卫星令人难以置信的长期遗产已经保存了地球40多年的历史。通过无数的应用程序&#xff0c;它甚至发现 island Landsat in Canada。 图片来源&#xff1a;NASA 2哨兵 作为 Copernicus Programme 哨兵的6个任务的舰队是一个游戏改变者。明确地…

2022年经典散文:滚烫的石板

滚烫的石板 ——灵遁者 此刻&#xff0c;我想表达的情愫大概有千万种&#xff0c;如何表达并不容易&#xff0c;就好像一个人的时候&#xff0c;也在面对某个我认识或者不认识的人&#xff0c;话总是说不清&#xff0c;也说不出来。 小孩总是敢于表达的&#xff0c;就像一条没…

.NET 7 的 AOT 到底能不能扛反编译?

一&#xff1a;背景 1.讲故事 在B站&#xff0c;公众号上发了一篇 AOT 的文章后&#xff0c;没想到反响还是挺大的&#xff0c;都称赞这个东西能抗反编译&#xff0c;可以让破解难度极大提高&#xff0c;可能有很多朋友对逆向不了解&#xff0c;以为用 ILSpy,Reflector,DnSpy…

群勃龙-半琥珀酸酯(TR-HS)与BSA牛血清白蛋白偶联 TR-HS-BSA

产品名称&#xff1a;群勃龙-半琥珀酸酯与牛血清白蛋白偶联 英文名称&#xff1a;TR-HS-BSA 用途&#xff1a;科研 状态&#xff1a;固体/粉末/溶液 产品规格&#xff1a;1g/5g/10g 保存&#xff1a;冷藏 储藏条件&#xff1a;-20℃ 储存时间&#xff1a;1年 牛血清中的简单蛋白…

全光谱台灯对孩子眼睛有影响吗?什么样的全光谱台灯真的有用

全光谱台灯对眼睛当然是有影响的&#xff0c;因为光谱成分丰富度与太阳光类似&#xff0c;所以无限接近于太阳光的显色能力&#xff0c;这样的灯光下物体的色差如同沐浴太阳光一般真实&#xff0c;色差不失真&#xff0c;人眼自然就越舒服。 那么什么样的全光谱台灯有用呢&…

Python|excel表格数据一键转json格式小工具|支持xlsx、xls格式转json|【源码+解析】

背景 最近在使用JavaScript编写一些浏览器RPA脚本&#xff0c;脚本使用过程中遇到一些问题&#xff0c;脚本使用的数据往往存放在excel表&#xff0c;但运行时只能读取json数据&#xff0c;导致频繁人工excel转json&#xff0c;效率低下。 遇到问题后赶紧搜索excel转json小工…

基于PHP+MySQL药品信息查询系统(含论文)

本系统阐述了医药信息查询系统的开发过程,并对该系统的需求分析及系统需要实现的设计方法作了介绍。该系统的基本功能包括用户注册登录,查看医药资讯,医药查询和在线留言等信息。 本系统技术介绍:php,mysql,apache,notepad,sublime.运行环境wamp,PHPstudy,xammp等php集成环境. …

FastAPI使用typing类型提示

typing是Python标准库&#xff0c;用来做类型提示。FastAPI使用typing做了&#xff1a; 编辑器支持&#xff1b; 类型检查&#xff1b; 定义类型&#xff0c;request path parameters, query parameters, headers, bodies, dependencies等等&#xff1b; 类型转换&#xff1…

去中心化应用的终极是应用链?

互操作性是近期在Web3兴起的概念&#xff0c;是指不同的计算机系统、网络、操作系统和应用程序一起工作并共享信息的能力。随着链上通信、语义交互逐渐复杂&#xff0c;链上用户多样的需求已然超出应用在单条链可承受的技术能力。 原本视作创新实验的Web3应用逐渐被公众接纳&am…

初识变量和数据类型

JavaScript第2天 输入输出语句 输出语句 alert(变量) > 弹出document.write(变量) > 输出在页面上面console.log(变量) > 打印在控制台上 /* JS的输出语句 */ alert("弹出") document.write("直接在写页面上面") console.log("打印在控制…

MacOS 如何选择鼠标不飘滚动平滑

MacOS 如何选择鼠标不飘滚动平滑 前言 今天不务正业的聊聊 macos 下的鼠标的事情&#xff0c;群里也有朋友和我聊&#xff0c;正好说说这事。 我在很长的时间里都在用 macbook pro 的触控板 键盘的高效模式&#xff0c;因为触控板和键盘很近所以效率很高。 但是有一个问题就是…

set和multiset容器

1、基本概念 所有元素在插入时会自动排好序&#xff1b; 属于关联式容器&#xff0c;底层结构是用二叉树实现的 2、set和multiset的区别 set中不允许有重复元素&#xff0c;multiset允许有重复元素。 3、构造和赋值 构造&#xff1a; set<T>st; //默认构造 set&l…

Linux | 进程间通信 | 匿名管道 | 命名管道 | 模拟代码实现进程通信

文章目录进程通信的意义匿名管道通信原理管道的访问控制进程控制管道的特点命名管道进程通信的意义 之前聊进程时&#xff0c;讲过一个性质&#xff0c;即进程具有独立性&#xff0c;两个进程之间的交互频率是比较少的。就连父子进程也只是共享代码&#xff0c;修改父子进程中…

小程序云开发笔记一

一、什么是云开发&#xff1f; 微信官方云原生开发平台&#xff0c;腾讯云的各种能力加持&#xff0c;用云开发开发者可以节省大量的开发时间和运维成本。 二、云开发优势 无需运维&#xff0c;数据变大不需要管理&#xff0c; 弹性伸缩&#xff0c;业务量变大&#xff0c;服…

在一台电脑上安装多个python版本(小白教程)

我自己的办公电脑是64位&#xff0c;好几个同事的电脑还是win7&#xff0c;32位&#xff0c;因此我在写python办公自动化的时候还要考虑32位的python&#xff0c;因此在电脑上安装了两个版本的python&#xff0c;方便测试、打包使用 1、首先&#xff0c;下载两个python&#xf…

代码随想录算法训练营第七天|LeetCode 454. 四数相加 II 、383. 赎金信、 15. 三数之和、18. 四数之和

LeetCode 454. 四数相加 II 题目链接&#xff1a;454. 四数相加 II 分析&#xff1a; 本题比较简单&#xff0c;因为是无关的四个数组&#xff0c;所以不需要考虑去重&#xff0c;所以用哈希比较简单 思路&#xff1a; 定义个无序map先将nums1和nums2的和的数都存进去&…

单目标应用:世界杯优化算法(World Cup Optimization,WCO)求解单仓库多旅行商问题SD-MTSP(可更改旅行商个数及起点)

一、世界杯优化算法 世界杯优化算法&#xff08;World Cup Optimization&#xff0c;WCO)由Navid Razmjooy等人于2016年提出&#xff0c;该算法模拟了国际足联世界杯比赛&#xff0c;思路新颖&#xff0c;收敛速度快&#xff0c;全局寻优能力强。 算法原理参考&#xff1a;智…

[附源码]java毕业设计学生宿舍管理系统

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…