elasticSearch DLS基础语句

2023-11-02 09:59

本文主要是介绍elasticSearch DLS基础语句,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

elasticSearch数据库和mysql数据库的差异

mysql                               ======》                     elasticSearch  

数据库(database)            在es叫做                      (索引数据库) index    

表(table)                     在es叫做                      (类型) type   

行(row)                       在es叫做                      (文档) document   

列(column)                 在es叫做                      (字段)field 

表结构                            在es叫做                      (映射) _mapping    

操作之前,要先安装elasticsearch 数据库,再安装kibana,不知道怎么安装? 点我试试

创建数据库

mysql                 create databse studentinfo            

在es操作                PUT /studentinfo                                                                

创建表

在studentinfo(数据库)创建表,表的字段:id、name、age、height、remark、isHealth、类型如下

mysql           

                 

在es操作                            

                 

(这里我就不在mysql去创建表了)                      type:类型,可以是text、long、short、date、integer、object等

                                                                              index:是否索引,默认为true

                                                                              store:是否存储,默认为false

                                                                              analyzer:分词器,这里的ik_max_word即使用ik分词器

查看表字段

mysql            desc table                                                  

在es操作         GET studentinfo/_mapping/student                            

新增数据

mysql                 insert into table value ('','','')                      

在es操作              # 插入数据(不指定id,这里的id指的是es的_id,唯一

# 插入数据(不指定id)
POST studentinfo/student
{"id":"1","name":"张三","age":"15","height":"1.45","isHealth":true,"remark":"中学生"
}

批量新增

mysql                      INSERT INTO testTable (xx,xx) VALUES ('xx','xx'),('xx','xx'),('xx','xx')          

在es操作                 #批量新增(注意这里格式必须要格式化一下,kibana 快捷键ctrl + i ,不然会报错)

#批量新增
POST /studentinfo/student/_bulk
{"index":{}}
{"name":"李四","age":"28","height":"1.65","isHealth":true,"remark":"社会打工人"}
{"index":{}}
{"name":"王五","age":"37","height":"1.75","isHealth":true,"remark":"管理人员"}
{"index":{}}
{"name":"赵六","age":"24","height":"1.65","isHealth":true,"remark":"大学毕业时"}
{"index":{}}
{"name":"田七","age":"24","height":"1.65","isHealth":true,"remark":"良好四民"}

根据id查询

mysql                          select * from table where id = 1               

在es操作                     GET studentinfo/student/1      

根据id修改 (没有就新增)

mysql                     update table set xxx where id = 1             

在es操作                    #修改 (没有即新增)                                               

#修改 (没有即新增)
PUT studentinfo/student/1
{"name":"张三指定id修改,这里注意看 _version 乐观锁机制 加1 ","age":"251","height":"2.45","isHealth":false,"remark":"中学生指定id 修改了"
}

根据id删除

mysql                                 delete from table where id = 1                   

在es操作                             DELETE /studentinfo/student/1

根据条件查询再删除

mysql                                      delete from table where id in (select id from table where name like '%张%')                   

在es操作                                  #根据条件去删除

#根据条件去删除
POST /studentinfo/_delete_by_query
{"query":{"match": {"name": "张"}}
}

#多字段查询

POST /studentinfo/_search
{"query": {"multi_match": {"query": "四","fields": ["name","remark"]}}
}

#精确查询(一般用于查询数字,时间)

#精确查询(一般用于查询数字,时间)
POST studentinfo/_search
{"query": {"term": {"height": {"value": "1.65"}}}
}

#多个值  精确查询(一般用于查询数字,时间)

#多个值  精确查询(一般用于查询数字,时间)
POST studentinfo/_search
{"query": {"terms": {"height": ["1.75","1.65"]}}
}

#查询指定字段

mysql                                   select id,name,height,xxx from table                       

在es操作                               #查询指定字段

#查询指定字段
POST studentinfo/_search
{"_source": ["name","remark","height"], "query": {"terms": {"height": ["1.75","1.65"]}}
}

#范围查询

mysql                               select * from table where age>=25 and age <30                       

在es操作                           #范围查询

#范围查询
POST studentinfo/_search
{"query": {"range": {"age": {"gte": 25,"lt": 30}}}
}

#排序 多字段

#排序 多字段
POST studentinfo/_search
{"query": {"match_all": {}},"sort": [{"age": {"order": "asc"}},{"_score": {"order": "asc"}}]
}

#高亮

#高亮
POST studentinfo/_search
{"query": {"match": {"name": "四"}},"highlight": {"pre_tags": "<b color='red'","post_tags": "<b>","fields": {"name": {}}}
}

#分页  分页公式:int start = {pageNum-1}*size

mysql                           select * from table limit 2,2                       

在es操作                      #分页  分页公式:int start = {pageNum-1}*size

#分页  分页公式:int start = {pageNum-1}*size
POST studentinfo/_search
{"query": {"match_all": {}},"from": 2,"size": 2
}

#地理查询

mysql     select * from xx where  a between 10.2  and  30.3

在es操作        

公式1: (不常用  根据两个点画出矩形,查询这个矩形内的所有东西)
GET /indexName/_search
{"query":{"geo_bounding_box":{"FIELD":{"top_left":{"lat":22.2,"lon":33.3},"bottom_right":{"lat":44.4,"lon":55.5},}}}
}公式2: (常用  以自己为中心,画出5km的半径,然后画一个圆 搜索圆里面的内容 )
GET /indexName/_search
{"query":{"geo_distance":{"FIELD":{"distance":"5km""FIELD":"11.1,22.2"}}}
}

 如果小伙伴们有什么疑问,欢迎下面评论。欢迎指正。如还有什么不懂的加我 QQ:517861659

如果没有及时回复,可以点我先问问AI机器人https://chatgpt.byabstudio.com/login?code=202307011314  

这篇关于elasticSearch DLS基础语句的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/329838

相关文章

ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法

《ElasticSearch+Kibana通过Docker部署到Linux服务器中操作方法》本文介绍了Elasticsearch的基本概念,包括文档和字段、索引和映射,还详细描述了如何通过Docker... 目录1、ElasticSearch概念2、ElasticSearch、Kibana和IK分词器部署

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Java实现Elasticsearch查询当前索引全部数据的完整代码

《Java实现Elasticsearch查询当前索引全部数据的完整代码》:本文主要介绍如何在Java中实现查询Elasticsearch索引中指定条件下的全部数据,通过设置滚动查询参数(scrol... 目录需求背景通常情况Java 实现查询 Elasticsearch 全部数据写在最后需求背景通常情况下

Java操作ElasticSearch的实例详解

《Java操作ElasticSearch的实例详解》Elasticsearch是一个分布式的搜索和分析引擎,广泛用于全文搜索、日志分析等场景,本文将介绍如何在Java应用中使用Elastics... 目录简介环境准备1. 安装 Elasticsearch2. 添加依赖连接 Elasticsearch1. 创

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close