ElasticSearch总结2

server/2024/11/29 10:52:02/

一、创建索引库:PUT

        ES中通过Restful请求操作索引库、文档。请求内容用DSL语句来表示。创建索引库和mapping的DSL语法如下:

        整个jason 里边,它有一个叫mapping的属性,代表的是映射。映射里边有properties代表就是字段。可以看到这里只有三个字段,然后每个字段都有一些自己的信息: type、analyzer、index...

我们先来复习一下mapping的常见属性: 

     需要注意的是,第三个字段这里还加了一个properties代表的子字段,这种就是带对象嵌套的方式: Object要结合properties声明子字段 

                                         

代码:
java">
PUT /heima
{"mappings":{"properties": {"info":{"type":"text","analyzer": "ik_smart"},"email":{"type":"keyword","index": false},"name":{"type":"object","properties": {"firstName":{"type":"keyword"},"lastName":{"type":"keyword"}}}}}
}

                                成功: 

    

二、查看、删除索引库: GET/DELETE

        

GET /heima 

java">{"heima" : {"aliases" : { },"mappings" : {"properties" : {"email" : {"type" : "keyword","index" : false},"info" : {"type" : "text","analyzer" : "ik_smart"},"name" : {"properties" : {"firstName" : {"type" : "keyword"},"lastName" : {"type" : "keyword"}}}}},"settings" : {"index" : {"routing" : {"allocation" : {"include" : {"_tier_preference" : "data_content"}}},"number_of_shards" : "1","provided_name" : "heima","creation_date" : "1714394468076","number_of_replicas" : "1","uuid" : "jgQAdwONRLqYAr2XfT9ZSA","version" : {"created" : "7120199"}}}}
}

                 DELETE /heima           删除后再查寻:GET /heima 

 

 三、添加字段:PUT /索引库名/_mapping

        索引库和mapping一旦创建无法修改,但是可以添加新的字段,语法如下:

        

        数据库里边一个表创建完了,理论还可以去修改表结构,但是在生产环境下,数据库一般情况下,我们也是尽量禁止去修改的,因为修改它的这个性能是影响非常大,可能会导致整个数据库不可用。 ES做的更彻底,索引库创建完了以后,是不允许修改的,当它的mapping映射都已经定义好了,ES会基于mapping去创建倒排索引。如果说你要去修改一个字段的话,可能导致我们原有的整个倒排索引失效,所以ES里边,是禁止修改索引库的,ES它虽然禁止你直接去修改原有的字段,但它允许你修改索引库的过程中添加新字段,它的语法是这样子的:

 代码:
java">#修改索引库,添加新的字段
PUT /heima/_mapping
{"properties":{"age":{"type":"integer"}}
}

         再调用GET /heima :多了一个age的属性:

                                

索引库和mapping一旦创建无法修改:

        但是如果说你现在把age再添加一次,你把它的类型改成long,这等于是在修改索引库结构,从integer改成long,报错了:  

四、添加文档:POST /索引库名/_doc/文档id

        新增文档的DSL语法:它是一个post请求,路径是一个索引库名,加上一个_doc,这是固定写法。后边跟上文档的i d, 其实就是告诉Kibana:我要新增的这个文档要到哪个库里面去。

        我这个文档的id是什么? 要写在路径的后边,这是Restful一种语法方式。如果你不加这个id,他就会认为你这个文档没有i d,将来ES会给你随机生成一个id:

代码:
java">#插入文档POST /heima/_doc/1
{"info":"程序员java","email":"123456@qqq.com","name":{"firstName":"张三","lastName":"李四"}
}

                        ​​​​​​​        

再插入一条不带id的:

java">POST /heima/_doc
{"info":"c++程序员","email":"6666@qq.com","name":{"firstName":"王五","lastName":"赵六"}
}

五、查询、删除文档 GET(DELETE)  /索引库名/_doc/文档id

查询代码: 

 GET /heima/_doc/1 

       这个信息给大家解读一下,_index代表他所在的索引库是“heima”,然后version1,这里其实有这个版本控制,每做一次文档修改,将来这个版本就会+1。然后_source就是你插入的那个原始文档,注意,这个_source就是你插入的原始文档。大家看是jason风格的原始文档:  

        ​​​​​​​        

 删除代码:

        DELETE /heima/_doc/1

                 

        可以看见删除后版本号+1,再次执行插入操作,版本号又+1 :

        ​​​​​​​        ​​​​​​​ 

  六、更新文档

方式一:全量修改,会删除旧文档:PUT /索引库名/_doc/文档id

  1、 全量修改和新增POST只有请求方式不同

  2 、如果传的这个id在索引库里不存在对应文档,这个删除的动作不会执行,新增不受影响

代码:
java">#插入文档POST /heima/_doc/2
{"info":"程序员javSa","email":"123456@qqq.Scom","name":{"firstName":"张三S","lastName":"李四S"}
}#更新文档
PUT /heima/_doc/2
{"info":"golang程序员","email":"99999@qq.com","name":{"firstName":"zhangsan","lastName":"lisi"}
}

 如果这个id不存在,那它就会变成新增操作:

方式二:增量修改,修改指定字段值:POST /索引库名/_update/文档id

代码: 
java">
POST /heima/_update/3
{"doc":{"email":"aaaa@qq.com"}
}

                         

七、 索引库、文档操作总结:

        ​​​​​​​        

        ​​​​​​​        

八、 


http://www.ppmy.cn/server/25740.html

相关文章

【Android】SharedPreferences阻塞问题深度分析

前言 Android中SharedPreferences已经广为诟病,它虽然是Android SDK中自带的数据存储API,但是因为存在设计上的缺陷,在处理大量数据时很容易导致UI线程阻塞或者ANR,Android官方最终在Jetpack库中提供了DataStore解决方案&#xf…

6.模板初阶

目录 1.泛型编程 2. 函数模板 2.1 函数模板概念 2.2函数模板格式 2.3 模板的实现 2.4函数模板的原理 2.5 函数模板的实例化 3.类模板 1.泛型编程 我们如何实现一个 交换函数呢? 使用函数重载虽然可以实现,但是有一下几个不好的地方: …

连锁企业如何通过OceanBase解决数据库瓶颈

本文来自OceanBase客户,重庆三十七度健康管理有限公司的技术负责人Rinvay的分享 背景 足疗养生对于大家来说应该并不陌生,自古以来便有多部古籍记载。尽管现代生活中,人们可能不再严格遵循节气进行泡脚,但在忙碌的工作间隙&#…

【设计模式】13、template 模板模式

文章目录 十三、template 模板模式13.1 ppl13.1.1 目录层级13.1.2 ppl_test.go13.1.3 ppl.go13.1.4 llm_ppl.go13.1.5 ocr_ppl.go 十三、template 模板模式 https://refactoringguru.cn/design-patterns/template-method 如果是一套标准流程, 但有多种实现, 可以用 template …

编译Qt6.5.3LTS版本(Mac/Windows)的mysql驱动(附带编译后的全部文件)

文章目录 0 背景1 编译过程2 福利参考 0 背景 因为项目要用到对MYSQL数据库操作,所以需要连接到MYSQL数据库。但是连接需要MYSQL驱动,但是Qt本身不自带MYSQL驱动,需要自行编译。网上有很多qt之前版本的mysql驱动,但是没有找到qt6…

【C语言】typedef

为一个数据类型起一个新的别名 typedef int INTEGER; INTEGER a,b; a1; b2;typedef char ARRAY20[20]; ARRAY20 a1,a2,s1,s2;typedef struct stu{char name[20];int age;char sex; }STU; STU body1,body2;typedef int (*PTR_TO_ARR)[4]; PTR_TO_ARR p1,p2;typedef int (*PTR_TO…

C++ 多态

C/C总述:Study C/C-CSDN博客 目录 多态概念 多态分类 多态实现 虚函数&虚函数表 虚函数的重写(覆盖) 多态的构成条件 虚函数重写的两个特例 协变 析构 关键字final和override(C11) 抽象类 纯虚函数…

设备能源数据采集新篇章

在当今这个信息化、智能化的时代,设备能源数据的采集已经成为企业高效运营、绿色发展的重要基石。而今天,我们要向大家介绍的就是一款颠覆传统、引领未来的设备能源数据采集神器——HiWoo Box网关! 一、HiWoo Box网关:一站式解决…