elasticsearch学习(五)文档CRUD

目录

上一篇文章

elasticsearch学习(四)kibana安装

https://blog.csdn.net/github_36801273/article/details/151076329?spm=1011.2124.3001.6209

文档CRUD

创建索引

复制代码
PUT /my-index
{
    "mappings": {
        "properties": {
                "testFieldA": {
                    "type": "text",
                    "fields": {
                        "keyword": {
                            "type": "keyword",
                            "ignore_above": 256
                        }
                    }
                },
                "testFieldB": {
                    "type": "text",
                    "fields": {
                        "keyword": {
                            "type": "keyword",
                            "ignore_above": 256
                        }
                    }
                }
            }
    }
}

mapping的部分不是必须的,可以通过先创建索引,然后写入数据的方式自动生成mapping

查看索引字段mapping

复制代码
GET /my-index/_mapping

{
  "my-index": {
    "mappings": {
      "properties": {
        "testFieldA": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        },
        "testFieldB": {
          "type": "text",
          "fields": {
            "keyword": {
              "type": "keyword",
              "ignore_above": 256
            }
          }
        }
      }
    }
  }
}

更新mapping

复制代码
POST  /my-index/_mapping
{
    "properties": {
        "testFieldC": {
            "type": "text",
            "fields": {
                "keyword": {
                    "type": "keyword",
                    "ignore_above": 256
                }
            }
        },
        "testFieldB": {
            "type": "text",
            "fields": {
                "keyword": {
                    "type": "keyword",
                    "ignore_above": 512
                }
            }
        }
    }
}

只能新增和更新字段,不能删除字段,删除字段用reindex

删除索引

复制代码
DELETE /my-index

测试索引是否存在

复制代码
HEAD /my-index

查看索引字段结构

复制代码
GET /my-index/_mapping

删除索引

复制代码
DELETE /my-index

文档命令

创建文档

Index

如果ID不存在,则创建新的,否则删除旧的再创建新的,增加版本号

复制代码
POST /my-index/_doc
{
    "id": "park_rocky-mountain",
    "title": "Rocky Mountain",
    "description": "Bisected north to south by the Continental Divide, this portion of the Rockies has ecosystems varying from over 150 riparian lakes to montane and subalpine forests to treeless alpine tundra."
}

Create

复制代码
// 不指定ID(系统自动生成)
POST /my-index/_doc
{
    "testFieldA":"testA1",
    "testFieldB":"testB1"
}

// 指定ID
POST /my-index/_doc/2
{
    "testFieldA":"testA2",
    "testFieldB":"testB2"
}
Create与Index的区别

create的文档ID如果已存在,会报失败

index的文档ID不存在,会新建,否则会把原来的删除了再增加

更新文档

复制代码
POST /my-index/_update/2
{
    "doc":{
        "testFieldA":"updateTestA2"
    } 
}

删除文档

复制代码
DELETE /my-index/_doc/2

查询文档

支持两种方式:

1 url查询,在url路径中使用查询参数

2 用DSL(Query Domain Specific Language)

简单查询语法

api 作用
/_search 查询集群上所有索引
/{index_name}/_search 查询指定索引
/{index_name1},{index_name2},{...}/_search 查询多个指定索引
/{index_prex}*/_search 查询以{index_prex}为开头的索引
复制代码
// 指定ID查询
GET /my-index/_doc/2

// 查询全量数据
GET /my-index/_search

// 查询my开头的索引数据
GET /my*/_search

// URL查询
GET /my-index/_search?q=testFieldA:updateTestA2

// DSL查询
GET /my-index/_search -H 'Content-Type:application/json' -d
{
    "query":{
        "match":{"testFieldA":"updateTestA2"}
    }
}
相关推荐
Lynnxiaowen15 小时前
今天我们开始学习Linux自动化运维Ansible基础
linux·运维·学习·自动化·云计算·ansible
YJlio16 小时前
VMMap 学习笔记(8.2):启动 VMMap、选择目标进程、权限要求与首次快照流程
服务器·笔记·学习
蓝桉~MLGT16 小时前
Python学习历程——模块
开发语言·python·学习
神的孩子都在歌唱16 小时前
es开源小工具 -- 分析器功能
大数据·elasticsearch·开源
say_fall17 小时前
C语言编程实战:每日刷题 - day 1
c语言·开发语言·学习
小苏兮17 小时前
【把Linux“聊”明白】进程的概念与状态
linux·运维·服务器·学习
楼田莉子18 小时前
C++/Linux小项目:自主shell命令解释器
linux·服务器·开发语言·c++·后端·学习
多喝开水少熬夜18 小时前
SlaugFL论文阅读学习
论文阅读·学习
搞机械的假程序猿18 小时前
普中51单片机学习笔记-按键
笔记·学习·51单片机
CodeLongBear18 小时前
MySQL进阶学习笔记:从单表查询到多表关联的深度解析(万字详解)
笔记·学习·mysql