索引操作
对比关系型数据库,创建索引就等同于创建数据库
创建索引
使用PUT请求创建索引,应为put具有幂等性,如果重复添加索引,会返回错误消息
http://192.168.80.10:9200/shopping
- acknowledged:响应结果
- shards_acknowledged:分片结果
- index:索引名称
查看索引
使用GET请求查看索引,_cat 表示查看的意思,indices 表示索引,是查看当前 ES服务器中的所有索引
http://192.168.80.10:9200/_cat/indices?v
表头 | 含义 |
---|---|
health | 当前服务器健康状态: green(集群完整) yellow(单点正常、集群不完整) red(单点不正常) |
status | 索引打开、关闭状态 |
index | 索引名 |
uuid | 索引统一编号 |
pri | 主分片数量 |
rep | 副本数量 |
docs.count | 文档数量 |
docs.deleted | 文档删除状态(逻辑删除) |
store.size | 主分片和副分片整体占空间大小 |
pri.store.size | 主分片占空间大小 |
使用GET,指定索引名称,查看单个索引
http://192.168.80.10:9200/shopping
- shopping:索引名
- aliases:别名
- mappings:映射
- settings:设置
- index:设置 - 索引
- creation_date:设置 - 索引 - 创建时间
- number_of_shards:设置 - 索引 - 主分片数量
- number_of_replicas:设置 - 索引 - 副分片数量
- uuid:设置 - 索引 - 唯一标识
- version:设置 - 索引 - 版本
- provided_name:设置 - 索引 - 名称
删除索引
使用DELETE,指定索引名称,删除单个索引
http://192.168.80.10:9200/shopping
文档操作
文档可以类比为关系型数据库中的表数据,添加的数据格式为 JSON 格式
创建文档
使用POST,指定索引名称,_doc,发送请求的方式必须为 POST,不能是 PUT,否则会发生错误,如果没有指定数据的唯一性标识ID,默认ES会随机生成,可以通过插入文档的时候,指定唯一性标识,如果增加数据时明确数据主键,那么请求方式也可以为 PUT
http://192.168.80.10:9200/shopping/_doc/1(指定唯一标识)
- _index:索引
- type:类型-文档
- id:唯一标识
- _version:版本
- result:结果
- _shards:分片
- total:分片 - 总数
- successful:分片 - 成功
- failed:分片 - 失败
查看文档
ES 服务器发 GET 请求 ,指定文档的唯一性标识,查看文档信息
http://192.168.80.10:9200/shopping/_doc/1
- _index:索引
- type:文档类型
- found:查询结果
- _source:文档源信息
修改文档
和新增文档一样,如果请求体变化,会将原有的数据内容覆盖
http://192.168.80.10:9200/shopping/_doc/1
{
"title":"华为手机",
"category":"华为",
"price":3999.00
}
- _version:版本
- result:结果
修改字段
修改数据时,也可以只修改某一给条数据的局部信息,发送POST请求
http://192.168.80.10:9200/shopping/_doc/1
{
"doc": {
"price": 5999.00
}
}
删除文档
向 ES 服务器发 DELETE 请求,删除一个文档不会立即从磁盘上移除,它只是被标记成已删除(逻辑删除)
http://192.168.80.10:9200/shopping/_doc/1
-
_version:对数据的操作,都会更新版本
-
result:结果deleted表示数据被标记为删除
条件删除文档
一般删除数据都是根据文档的唯一性标识进行删除,实际操作时,也可以根据条件对多条数据进行删除_delete_by_query
http://192.168.80.10:9200/shopping/_doc/_delete_by_query
{
"query": {
"match": {
"price": 4000.00
}
}
}
- took:耗时
- timed_out:是否超时
- total:总数
- deleted:删除数量
映射操作
有了索引库,等于有了数据库中的 database。而索引库(index)中的映射,类似于数据库(database)中的表结构(table)。 创建数据库表需要设置字段名称,类型,长度,约束等;索引库也一样,需要知道这个类型下有哪些字段,每个字段有哪些约束信息,这就叫做映射(mapping)。
映射数据说明
字段名:任意填写,下面指定许多属性,例如: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 分词器
创建映射
向 ES 服务器发 PUT 请求
http://192.168.80.10:9200/student/_mapping
{
"properties": {
"name": {
"type": "text",
"index": true
},
"sex": {
"type": "text",
"index": false
},
"age": {
"type": "long",
"index": false
}
}
}
查看映射
向 ES 服务器发 GET 请求
http://192.168.80.10:9200/student/_mapping
索引映射关联
向 ES 服务器发 PUT 请求
http://192.168.80.10:9200/student
{
"settings": {},
"mappings": {
"properties": {
"name": {
"type": "text",
"index": true
},
"sex": {
"type": "text",
"index": false
},
"age": {
"type": "long",
"index": false
}
}
}
}